mysql 发生死锁问题请求帮助
1个回答
2017-09-17
展开全部
这是我见的一个文档,虽然我看不懂,你看看有没有帮助MySQL死锁问题的相关知识是本文我们主要要介绍的内容,接下来我们就来一一介绍这部分内容,希望能够对您有所帮助。1、MySQL常用存储引擎的锁机制MyISAM和MEMORY采用表级锁(table-levellocking)BDB采用页面锁(page-levellocking)或表级锁,默认为页面锁InnoDB支持行级锁(row-levellocking)和表级锁,默认为行级锁2、各种锁特点表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般3、各种锁的适用场景表级锁更适合于以查询为主,只有少量按索引条件更新数据的应用,如Web应用行级锁则更适合于有大量按索引条件并发更新数据,同时又有并发查询的应用,如一些在线事务处理系统4、死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。表级锁不会产生死锁。所以解决死锁主要还是针对于最常用的InnoDB。5、死锁举例分析在MySQL中,行级锁并不是直接锁记录,而是锁索引。索引分为主键索引和非主键索引两种,如果一条sql语句操作了主键索引,MySQL就会锁定这条主键索引;如果一条语句操作了非主键索引,MySQL会先锁定该非主键索引,再锁定相关的主键索引。在UPDATE、DELETE操作时,MySQL不仅锁定WHERE条件扫描过的所有索引记录,而且会锁定相邻的键值,即所谓的next-keylocking。例如,一个表db。tab_test,结构如下:id:主键;state:状态;time:时间;索引:idx_1(state,time)出现死锁日志如下:?***(1)TRANSACTION:?TRANSACTION0677833455,ACTIVE0sec,processno11393,OSthreadid278546startingindexread?mysqltablesinuse1,locked1?LOCKWAIT3lockstruct(s),heapsize320?MySQLthreadid83,queryid162348740dcnet03dcnetSearchingrowsforupdate?updatetab_testsetstate=1064,time=now()wherestate=1061andtime
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询