写在前面的话

在前面的内容中提到过,在以前的 MyISAM 中锁是表级锁,InnoDB 是行级锁。这个锁到底是啥样,怎么找出来,这一节就主要做这个。

定位锁的问题

上一节我们创建了一个 1000万数据的表,这里会用到。

假设这样一个场景,我们 top 看到服务器 CPU 占用超级高,等待也很高,查询慢日志发现有些 SQL 执行特别久。

1. 查看锁等待:

在一个 session 中执行:

use testdb1;
UPDATE t_100w SET k1='az' WHERE id=10008;

在另外一个 session 中执行:

use testdb1;
UPDATE t_100w SET k1='qz' WHERE id=10008;

在另外一个 session 此时我们查看:

show status like 'innodb_row_lock%';

结果:

可以看到有一个 row lock 等待。

2. 查看哪个事务在等待:

select * from information_schema.INNODB_TRX where trx_state='LOCK WAIT'\G

结果:

其中主要的几个参数:

trx_id:事务 ID

trx_state:事务状态

trx_mysql_thread_id:连接线程的 ID,就是 show processlist 看到的 ID。

trx_query:当前被阻塞的 SQL

3. 查看谁锁的:

select * from sys.innodb_lock_waits\G

结果:

locked_table:哪张表被锁住。

waiting_trx_id:等待的事务 ID。

waiting_pid:等待的线程号。

blocking_trx_id:锁源的事务 ID。

blocking_pid:锁源的线程号。

4. 查看锁源:

select * from performance_schema.threads where processlist_id=3\G

通过上一步获取到的锁源 PID 查询:

5. 找到具体锁的 SQL 是哪一个。

-- 当前在执行的语句
SELECT * FROM performance_schema.`events_statements_current` WHERE thread_id=41;
-- 执行语句的历史
SELECT * FROM performance_schema.`events_statements_history` WHERE thread_id=41;

涉及到锁监控的一些命令:

show status like 'innodb_rows_lock%'
select * from information_schema.innodb_trx;
select * from sys.innodb_lock_waits;
select * from performance_schema.threads;
select * from performance_schema.events_statements_current;
select * from performance_schema.events_statements_history;

处理锁的问题

当我们发现锁并且定位到具体的 SQL 以后,就需要对该问题进行处理:

1. 当 SQL 不是很重要,不是什么大事务或者重要的事务的时候,我们可以通过 kill 的方式杀掉 processlist 中的 PID。

2. 当然最终的决绝办法还是让开发修改业务处理逻辑。

对于死锁,我们可以将其记录到日志中,设置方法:

innodb_print_all_deadlocks = 1 

小结

业务中很容易出现锁的情况,毕竟开发水平参差不齐,有些烂 SQL 没法避免。这就需要我们使用慢日志结合锁监控一起,定位问题,最终优化解决问题。

最新文章

  1. 使用maven给spring项目打可直接运行的jar包(配置文件内置外置的打法)
  2. hdu 5901 Count primes
  3. Yii2美化confirm
  4. inotify配合rsync实现文件同步
  5. 关于oracle误删数据的恢复
  6. SQL Server使用规范(转)
  7. 解决TabActivity中子页面不通过导航跳转到还有一个页面的问题
  8. windows下搭建Cygwin环境
  9. Docker - 定制镜像
  10. 内核对象kobject和sysfs(3)——kobj分析
  11. Python:list 和 array的对比以及转换时的注意事项
  12. 老男孩Python全栈开发(92天全)视频教程 自学笔记21
  13. 刀客139qq算命
  14. Jmeter使用插件监控服务器资源的使用情况
  15. 强大的Notepad++,竟然还是自由使用的
  16. laravel简书(2)
  17. golang学习笔记12 beego table name `xxx` repeat register, must be unique 错误问题
  18. Spring Security教程(六):自定义过滤器进行认证处理
  19. hadoop之 exceeds the limit of concurrent xcievers处理
  20. pygame系列_第一个程序_图片代替鼠标移动

热门文章

  1. FTP安装及配置
  2. ubuntu18.04因java路径原因启动jenkins失败
  3. CCPC 2019 秦皇岛 Angle Beats
  4. 2019-2020-1 20199305《Linux内核原理与分析》第九周作业
  5. 洛谷 UVA10226 Hardwood Species
  6. Git push error: http 411的解决方案总结
  7. NIO中Buffer的重要属性关系解析
  8. HTTP中的Accept-Encoding、Content-Encoding、Transfer-Encoding、Content-Type
  9. WebMagic使用代理ip爬数据解决HTTP407问题
  10. [Go] protobuffer 的环境配置