当前位置:首页 » 《随便一记》 » 正文

【第25天】SQL进阶-查询优化- performance_schema系列实战二:锁问题排查(全局读锁)(SQL 小虚竹)

20 人参与  2023年01月21日 10:41  分类 : 《随便一记》  评论

点击全文阅读


回城传送–》《32天SQL筑基》

文章目录

零、前言一、什么是全局锁二、什么时候适合加全局锁三、实战演练3.1 数据准备(如果已有数据可跳过此操作)3.2 开启第一个会话,执行全局读锁3.3 开启第二个会话,修改表数据3.4 开启第三个会话,进行排查3.5 分析3.6 释放全局读锁 四、总结五、参考

零、前言

今天是学习 SQL 打卡的第 25 天,每天我会提供一篇文章供群成员阅读( 不需要订阅付钱 )。

希望大家先自己思考,如果实在没有想法,再看下面的解题思路,自己再实现一遍。在小虚竹JAVA社区 中对应的 【打卡贴】打卡,今天的任务就算完成了,养成每天学习打卡的好习惯。

​ 虚竹哥会组织大家一起学习同一篇文章,所以有什么问题都可以在群里问,群里的小伙伴可以迅速地帮到你,一个人可以走得很快,一群人可以走得很远,有一起学习交流的战友,是多么幸运的事情。

​ 我的学习策略很简单,题海策略+ 费曼学习法。如果能把这些题都认认真真自己实现一遍,那意味着 SQL 已经筑基成功了。后面的进阶学习,可以继续跟着我,一起走向架构师之路。

今天的学习内容是:SQL进阶-查询优化- performance_schema系列实战二:锁问题排查(全局读锁)

一、什么是全局锁

全局锁是对整个数据库来说的,当对数据库加了全局读锁,任何请求都不能对数据库进行加写锁操作了;当对数据库加了全局写锁,后面对数据库的加读锁和写锁操作会被阻塞。

二、什么时候适合加全局锁

全局锁适合在进行主从备份数据、或者导入导出数据的时候才会对全局进行加锁。

三、实战演练

在MySQL 5.7之前的版本,要排查谁持有全局读锁通常在数据库层面是很难直接查询到有用数据(innodb_locks表也只能记录innodb层的锁信息,而全局读锁是server层的锁,所以也无法查询到)。

从MySQL 5.7开始提供表performance_schema.metadata_locks表记录一些Server层的锁信息(包括全局读锁和MDL锁等),下面我们通过一个示例来演示然后使用performance_schema来找出谁持有全局读锁。

3.1 数据准备(如果已有数据可跳过此操作)

使用sysbench准备初始化数据
创建测试数据库sysbenchdemo

create database sysbenchdemo;

在这里插入图片描述
准备测试数据:

sysbench /usr/share/sysbench/oltp_insert.lua \--mysql-host=localhost \--mysql-port=3306 \--mysql-socket=/tmp/mysql.sock \--mysql-user=root \--mysql-password=xiaoxuzhu \--mysql-db=sysbenchdemo \--db-driver=mysql \--tables=8 \--table-size=100000 \--time=180 prepare

在这里插入图片描述

3.2 开启第一个会话,执行全局读锁

登录mysql数据库

use sysbenchdemo;

在这里插入图片描述
执行加锁语句

flush table with read lock;

在这里插入图片描述
查询以下加锁线程的process id,以便后续排查过程好对应

select connection_id();

在这里插入图片描述

3.3 开启第二个会话,修改表数据

登录mysql数据库

use sysbenchdemo;

在这里插入图片描述
查询sbtest1表的第一条数据

select * from sbtest1 limit 1;

在这里插入图片描述
查询当前线程的process id,以便后续排查过程好对应

select connection_id();

在这里插入图片描述

修改sbtest1表的第一条数据

update sbtest1 set pad='xxx' where id=1;

在这里插入图片描述
会发现,修改不了,一直处于堵塞。

3.4 开启第三个会话,进行排查

我们还可以通过performance_schema.metadata_locks表来排查谁持有全局读锁,全局读锁通常在该表记录着同一个会话的OBJECT_TYPE为global和commit、LOCK_TYPE都为SHARED的两把显式锁

select * from performance_schema.metadata_locks where OWNER_THREAD_ID!=sys.ps_thread_id(connection_id());

在这里插入图片描述
其中OWNER_THREAD_ID: # 持有锁的内部线程ID

查看process id为 12372,12427 各自对应的内部线程ID是多少

select sys.ps_thread_id(12372);

在这里插入图片描述
process id=12372的线程对应的内部线程ID正好为12536,说明就是process id=12372的线程持有了全局读锁

select sys.ps_thread_id(12427);

在这里插入图片描述

proces id=12427的线程对应的内部线程正好是12591,说明在等待全局读锁的就是process id=12427的线程

3.5 分析

结合上面的分析,再通过 show processlist找到对应行记录信息,就可大概推测出这是哪个的业务语句。
在这里插入图片描述

3.6 释放全局读锁

在产生阻塞的会话内释放全局读锁。

unlock tables;

在这里插入图片描述
查看第二个会话,发现执行了修改语句。释放全局读锁成功。
在这里插入图片描述

四、总结

通过本文学习,学会了什么是全局锁以及全局锁的适用场景,通过实战演练排查全局读锁问题,从理论到实战的介绍,可以加深对全局锁的理解。

五、参考

应用示例荟萃 | performance_schema全方位介绍(上)

我是虚竹哥,我们明天见~


点击全文阅读


本文链接:http://zhangshiyu.com/post/51687.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 进错房,嫁给八零最牛特种兵已完结(林晚夏江肆年)抖音热文_《进错房,嫁给八零最牛特种兵已完结》最新章节免费在线阅读 -
  • 重生后选魔族,天族哭着求我当王全章节(月沁雪任意)全文免费阅读无弹窗大结局_(重生后选魔族,天族哭着求我当王全章节)重生后选魔族,天族哭着求我当王全章节免费阅读全文最新章节列表_笔趣阁(重生后选魔族,天族哭着求我当王全章节) -
  • 捡回摄政王后,她在皇室作威作福完结版小说(景飞鸢赵灵杰)全文免费阅读无弹窗大结局_(捡回摄政王后,她在皇室作威作福完结版免费阅读全文大结局)最新章节列表_笔趣阁(捡回摄政王后,她在皇室作威作福完结版) -
  • 千金难泣(立轩苏子骞翠竹吴进)全本免费在线阅读_千金难泣最新章节在线阅读(立轩苏子骞翠竹吴进)
  • 《沈云阶傅宴辞》(沈云阶傅宴辞》已完结完整版全集大结局小说)全文阅读笔趣阁
  • 《沈凌峰沈国华》已完结小说全文阅读笔趣阁《沈凌峰沈国华》
  • 《傅嫤韩恬魏郯程茂》已完结(傅嫤韩恬魏郯程茂)热门小说全目录完整版)全文阅读笔趣阁
  • 八零俏军医错嫁糙汉军官:番外+全文+后续(贺昭朗孟翩然)完本小说免费_全本免费小说八零俏军医错嫁糙汉军官:番外+全文+后续最新小说全文阅读(贺昭朗孟翩然)
  • 失去千千万万遍在线阅读(阮相宜陆凛言)全文免费阅读无弹窗大结局_(失去千千万万遍在线阅读)失去千千万万遍在线阅读免费阅读全文最新章节列表_笔趣阁(失去千千万万遍在线阅读) -
  • 脱离世界后,妻子疯了火爆小说小说(沈夕颜林程言)全文免费阅读无弹窗大结局_(脱离世界后,妻子疯了火爆小说免费阅读全文大结局)最新章节列表_笔趣阁(脱离世界后,妻子疯了火爆小说) -
  • 跨年发生踩踏,男友为救白月光丢下我(温林初宝宝)免费阅读 -
  • 都重生了,还不离婚等啥呢宋招弟霍文铮小说在线章节免费阅读

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1