当前位置: 首页 > article >正文

MySQL的锁机制及排查锁问题

MySQL的锁机制及排查锁问题

文章目录

  • MySQL的锁机制及排查锁问题
    • MySQL的锁机制
    • 排查锁的问题

MySQL的锁机制

  1. 按照锁的粒度可以分为行锁和表锁,按照是否可写可以分为读锁和写锁。
  2. 行锁是MySQL中粒度最细的锁,对当前操作的行进行加锁。行锁会大大减少数据库操作的冲突,加锁的粒度最小,但是加锁的开销最大,有可能会出现死锁。
  3. 行锁的实现算法有Record Lock记录锁、Gap Lock间隙锁和Next-key Lock。记录锁是对单行记录加锁,对索引项加锁,锁定符合条件的行,其他事务不能修改和删除加锁项。间隙锁锁定的是一个范围,不包含记录本身。对索引项之间的间隙加锁,锁定记录的范围,对第一条记录前的间隙或最后一条记录后的间隙加锁,不包含索引项本身。其他事务不能在锁范围内插入数据,这样可以防止其他事务新增幻影行。Next-key Lock是默认的锁,同时锁住数据和间隙锁。锁定索引项本身和索引范围。
  4. 表锁是MySQL中粒度最大的锁,对当前正在操作的整张表加锁,资源开销比行锁少,不会出现死锁的情况,但是发生锁冲突的概率比较大。InnoDB默认的是行锁。
  5. 读锁也成为共享锁,其他用户可以并发读取数据,但任何事务都不能获取数据上的写锁,直到释放所有的读锁。
  6. 写锁也成为排他锁,如果事务T对数据对象A加上写锁,就只允许事务T读取和修改数据对象A。

排查锁的问题

  1. 排查锁的问题可以从表锁和行锁考虑。
  2. 查看表锁的情况后分析。
-- 查看所有线程
show full processlist;
-- 查看正在使用的表
show open tables;
-- 查看innodb服务器信息
show engine innodb status;
-- 查看表锁:Table_locks_waited-出现表锁争用而发生的等待次数,Table_locks_immediate-可以立即获取锁的次数
show status like 'table%';
  1. 查看行锁的情况
-- Innodb_row_lock_current_waits:当前正在等待锁定的数量
-- Innodb_row_lock_time:从系统启动到现在锁定的总时间
-- Innodb_row_lock_time_avg:每次等待所花的平均时间
-- Innodb_row_lock_time_max:从系统启动到现在等待最长的一次所花的时间
-- Innodb_row_lock_waites:从系统启动到现在总共等待的次数
show status like 'innodb_row_lock%';
-- 查看information_schema库
-- innodb_trx表用来显示当前运行innodb事务情况,不能判断锁的情况
-- innodb_locks表可以查看锁的情况
-- innodb_lock_waits表可以查看锁等待的情况

http://www.kler.cn/a/464117.html

相关文章:

  • QML自定义进度条和单选按钮的样式
  • 250103-逻辑运算符
  • 给vscode的新项目选择虚拟环境
  • JVM实战—9.线上FGC的几种案例
  • 生成对抗网络 (Generative Adversarial Network, GAN) 算法MNIST图像生成任务及CelebA图像超分辨率任务
  • 需求上线,为什么要刷缓存?
  • 手机更换屏幕后,会被防控软件识别为模拟器!!
  • 02-专业问题
  • 基于SpringBoot和OAuth2,实现通过Github授权登录应用
  • wx014基于springboot+vue+uniapp的智能小程序商城
  • 六年之约day5
  • python脚本,读取当前目录文件名,写入excel表格,并给对应文件名分配mac
  • 动态规划模式
  • 精密制造动力箱行业需要哪种多功能电表
  • 地理数据库Telepg面试内容整理-相关技术与工具
  • 【C语言】如何插入并播放音频文件
  • 高级架构五 设计模式
  • python中序列化之json文件的使用
  • Redis 发布订阅(Pub/Sub)机制详解
  • Switch组件的用法
  • 《我在技术交流群算命》(二):QGraphicsItem怎么写自定义信号啊(QObject多继承顺序问题)
  • 深入解析 JVM vs JDK vs JRE:三者区别与联系详解
  • python opencv的orb特征检测(Oriented FAST and Rotated BRIEF)
  • LevelDB 源码阅读:利用 Clang 的静态线程安全分析
  • 彻底解决 Selenium ChromeDriver 不匹配问题:Selenium ChromeDriver 最新版本下载安装教程
  • 概率论与数理统计