怎么解开mysql表 mysql数据库锁表如何解锁( 二 )


搜索的结果中 , 如果在事务表发现了很多任务,最好都kill掉 。
执行kill命令:
对应的线程都执行完kill命令之后,后续事务便可正常处理 。
针对紧急情况,通常也会直接操作第一、第二、第六步 。
这里再补充一些MySQL锁相关的知识点:数据库锁设计的初衷是处理并发问题 , 作为多用户共享的资源 , 当出现并发访问的时候,数据库需要合理地控制资源的访问规则 , 而锁就是用来实现这些访问规则的重要数据结构 。
根据加锁的范围,MySQL里面的锁大致可以分成全局锁、表级锁和行锁三类 。MySQL中表级别的锁有两种:一种是表锁,一种是元数据锁(metadata lock,MDL) 。
表锁是在Server层实现的 , ALTER TABLE之类的语句会使用表锁,忽略存储引擎的锁机制 。表锁通过lock tables… read/write来实现 , 而对于InnoDB来说,一般会采用行级锁 。毕竟锁住整张表影响范围太大了 。
另外一个表级锁是MDL(metadata lock),用于并发情况下维护数据的一致性,保证读写的正确性,不需要显式的使用 , 在访问一张表时会被自动加上 。
常见的一种锁表场景就是有事务操作处于:Waiting for table metadata lock状态 。
MySQL在进行alter table等DDL操作时 , 有时会出现Waiting for table metadata lock的等待场景 。
一旦alter table TableA的操作停滞在Waiting for table metadata lock状态,后续对该表的任何操作(包括读)都无法进行,因为它们也会在Opening tables的阶段进入到Waiting for table metadata lock的锁等待队列 。如果核心表出现了锁等待队列 , 就会造成灾难性的后果 。
通过show processlist可以看到表上有正在进行的操作(包括读),此时alter table语句无法获取到metadata 独占锁 , 会进行等待 。
通过show processlist看不到表上有任何操作,但实际上存在有未提交的事务,可以在information_schema.innodb_trx中查看到 。在事务没有完成之前,表上的锁不会释放,alter table同样获取不到metadata的独占锁 。
处理方法:通过 select * from information_schema.innodb_trxG, 找到未提交事物的sid , 然后kill掉 , 让其回滚 。
通过show processlist看不到表上有任何操作,在information_schema.innodb_trx中也没有任何进行中的事务 。很可能是因为在一个显式的事务中,对表进行了一个失败的操作(比如查询了一个不存在的字段) , 这时事务没有开始,但是失败语句获取到的锁依然有效 , 没有释放 。从performance_schema.events_statements_current表中可以查到失败的语句 。
处理方法:通过performance_schema.events_statements_current找到其sid,kill 掉该session , 也可以kill掉DDL所在的session 。
总之 , alter table的语句是很危险的(核心是未提交事务或者长事务导致的),在操作之前要确认对要操作的表没有任何进行中的操作、没有未提交事务、也没有显式事务中的报错语句 。
如果有alter table的维护任务,在无人监管的时候运行,最好通过lock_wait_timeout设置好超时时间,避免长时间的metedata锁等待 。
关于MySQL的锁表其实还有很多其怎么解开mysql表他场景 , 我们在实践的过程中尽量避免锁表情况的发生,当然这需要一定经验的支撑 。但更重要的是 , 如果发现锁表我们要能够快速的响应,快速的解决问题,避免影响正常业务 , 避免情况进一步恶化 。所以,本文中的解决思路大家一定要收藏或记忆一下,做到有备无患,避免突然状况下抓瞎 。
怎么解开mysql表的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于mysql数据库锁表如何解锁、怎么解开mysql表的信息别忘了在本站进行查找喔 。

推荐阅读