MySQL锁表和解锁操作1、确定mysql有锁表的情况则使用以下命令查看锁表进程
2、杀掉查询结果中已经锁表的trx_mysql_thread_id
扩展:
1、查看锁的事务
2、查看等待锁的事务
3、查询是否锁表:
4、查询进程
MySQL数据库表被锁、解锁,删除事务在程序员的职业生涯中 , 总会遇到数据库表被锁的情况,前些天就又撞见一次 。由于业务突发需求,各个部门都在批量操作、导出数据,而数据库又未做读写分离,结果就是:数据库的某张表被锁了!
用户反馈系统部分功能无法使用,紧急排查,定位是数据库表被锁,然后进行紧急处理 。这篇文章给大家讲讲遇到类似紧急状况的排查及解决过程,建议点赞收藏 , 以备不时之需 。
用户反馈某功能页面报502错误,于是第一时间看服务是否正常 , 数据库是否正常 。在控制台看到数据库CPU飙升,堆积大量未提交事务,部分事务已经阻塞了很长时间,基本定位是数据库层出现问题了 。
查看阻塞事务列表 , 发现其中有锁表现象 , 本想利用控制台直接结束掉阻塞的事务,但控制台账号权限有限,于是通过客户端登录对应账号将锁表事务kill掉,才避免了情况恶化 。
下面就聊聊,如果当突然面对类似的情况,我们该如何紧急响应?
想象一个场景,当然也是软件工程师职业生涯中会遇到的一种场景:原本运行正常的程序,某一天突然数据库的表被锁了,业务无法正常运转,那么我们该如何快速定位是哪个事务锁了表,如何结束对应的事物?
首先最简单粗暴的方式就是:重启MySQL 。对的,网管解决问题的神器——“重启” 。至于后果如何,你能不能跑了,要你自己三思而后行了!
重启是可以解决表被锁的问题的,但针对线上业务很显然不太具有可行性 。
下面来看看不用跑路的解决方案:
遇到数据库阻塞问题,首先要查询一下表是否在使用 。
如果查询结果为空,那么说明表没在使用 , 说明不是锁表的问题 。
如果查询结果不为空,比如出现如下结果:
则说明表(test)正在被使用,此时需要进一步排查 。
查看数据库当前的进程 , 看看是否有慢SQL或被阻塞的线程 。
执行命令:
该命令只显示当前用户正在运行的线程,当然,如果是root用户是能看到所有的 。
在上述实践中 , 阿里云控制台之所以能够查看到所有的线程,猜测应该使用的就是root用户,而笔者去kill的时候,无法kill掉,是因为登录的用户非root的数据库账号,无法操作另外一个用户的线程 。
如果情况紧急,此步骤可以跳过,主要用来查看核对:
如果情况紧急,此步骤可以跳过 , 主要用来查看核对:
看事务表INNODB_TRX中是否有正在锁定的事务线程,看看ID是否在show processlist的sleep线程中 。如果在,说明这个sleep的线程事务一直没有commit或者rollback , 而是卡住了,需要手动kill掉 。
搜索的结果中,如果在事务表发现了很多任务,最好都kill掉 。
执行kill命令:
对应的线程都执行完kill命令之后,后续事务便可正常处理 。
针对紧急情况 , 通常也会直接操作第一、第二、第六步 。
这里再补充一些MySQL锁相关的知识点:数据库锁设计的初衷是处理并发问题,作为多用户共享的资源,当出现并发访问的时候,数据库需要合理地控制资源的访问规则,而锁就是用来实现这些访问规则的重要数据结构 。
根据加锁的范围,MySQL里面的锁大致可以分成全局锁、表级锁和行锁三类 。MySQL中表级别的锁有两种:一种是表锁 , 一种是元数据锁(metadata lock,MDL) 。
推荐阅读
- 浏览视频会留下什么缓存,浏览器看视频会有缓存吗
- 小说浏览器下载,小说浏览器下载
- oracle怎么关联表,oracle关联语句
- 电商营销如何塑造品牌形象,电商品牌应如何打造品牌
- php获取爱奇艺数据源 爱奇艺数据库
- 中医馆如何引流客户,中医馆如何拓客
- ERP系统变慢检测方法,erp系统bug
- c语言气泡法怎么调用函数 c语言写一个函数用起泡法
- 华为字体下载,华为字体下载记录怎么删除