【MySQL】MySQL锁冲突排障纪要

【MySQL】MySQL锁冲突排障纪要

  • 开篇词:
  • 干货篇:
      • 1.查看当前innodb status,里面包含事务,锁占用情况
      • 2.查看mysql进程状态
      • 3.查看innodb事务,锁,锁等待情况
      • 4.定位持有锁的线程信息
  • 总结篇:
      • 一、锁冲突的原因
      • 二、锁冲突的表现
      • 三、解决锁冲突的方法
      • 四、锁冲突的监控与诊断
  • 我是杰叔叔,一名沪漂的码农,下期再会!

开篇词:

记一次事务导致MySQL锁冲突排障纪要

干货篇:

1.查看当前innodb status,里面包含事务,锁占用情况

show engine innodb status;

2.查看mysql进程状态

show full processlist;
select * from information_schema.PROCESSLIST p where
db=‘smart_agent-service’ and HOST like ‘127.0.0.1%’

3.查看innodb事务,锁,锁等待情况

只有发生锁等待的情况下,后两张表才有内容
select * from information_schema.INNODB.TRX
select * from information_schema.INNODB.LOCKS
select * from information_schema.INNODB.LOCKS_WAITS

4.定位持有锁的线程信息

select * from information_schema.PROCESSLIST p innenr join
information_schema.INNODB.TRX it
on p.id = it.trx_mysql_thread_id where trx_table_locked > 0 and
trx_rows_locked > 0;

总结篇:

MySQL锁冲突是数据库并发操作中常见的问题,它发生在多个事务或查询同时尝试访问或修改同一数据资源时。以下是MySQL锁冲突的详细总结:

一、锁冲突的原因

  • 并发事务:多个事务同时访问和修改相同的数据资源,导致锁的竞争。
  • 锁的获取与释放:事务在对数据进行操作时需要获取相应的锁,如果某个事务已经持有了某个锁,而另一个事务也需要获取相同的锁,就会出现锁冲突。
  • 锁的模式和类型:MySQL支持多种锁模式和类型,如共享锁(读锁)和排他锁(写锁),以及表级锁、行级锁等。不同的事务可能需要不同类型的锁,从而引发冲突。
  • 事务隔离级别:不同的事务隔离级别对锁的获取和释放方式有不同的要求,可能导致锁冲突的发生。
  • 长事务:长事务持有锁的时间过长,增加了与其他事务发生锁冲突的概率。

二、锁冲突的表现

  • 查询等待:当一个事务尝试获取已被其他事务持有的锁时,该事务会进入等待状态,直到锁被释放。
  • 死锁:两个或多个事务在执行过程中,因争夺资源而造成一种互相等待的现象,若无外力作用,它们都将无法推进下去,形成死锁。
  • 锁超时:在某些情况下,如果事务等待锁的时间过长,可能会触发锁超时错误,导致事务失败。

三、解决锁冲突的方法

  • 优化数据库设计:通过合理的数据库设计减少事务之间的冲突概率,如将频繁更新的数据拆分到不同的表中。
  • 调整事务的并发度:适当控制事务的并发量,避免过高的并发度导致事务间的互相等待。
  • 提高数据库服务器性能:增加硬件资源、优化服务器配置参数等,以减少事务的执行时间,从而降低锁冲突的可能性。
  • 选择合适的锁粒度:根据业务场景选择合适的锁粒度,避免锁粒度过大导致的互相等待或锁粒度过小增加的系统开销。
  • 设置合理的事务隔离级别:根据业务要求选择合适的隔离级别,以平衡数据一致性和性能。
  • 使用事务回滚:在发生死锁时,可以通过回滚其中一个或多个事务来解除死锁。
  • 监控和调优:使用监控工具对数据库的锁冲突和死锁进行实时监控,及时发现和解决问题。

四、锁冲突的监控与诊断

  • 查看锁等待情况:通过MySQL的SHOW ENGINE INNODB STATUS命令查看锁等待情况,了解哪些事务正在等待锁以及等待的原因。
  • 分析死锁日志:MySQL会在检测到死锁时记录死锁日志,通过分析死锁日志可以了解死锁的原因和涉及的事务。
  • 使用性能监控工具:利用性能监控工具(如Percona Toolkit、MySQL Workbench等)对数据库的锁冲突和性能进行实时监控和分析。

在这里插入图片描述

我是杰叔叔,一名沪漂的码农,下期再会!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/766901.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Python】列表

目录 一、列表的概念 二、列表的创建 1.变量名 [ ] ..... 2.通过Python内置 的I ist类的构造函数来创建列表 三、操作列表元素的方法 1. 修改 2. 增加元素 3. 删除 4. 其他操作 四、遍历列表 五、列表排序 六、列表切片(list slicing) 七、…

Python入门 2024/7/2

目录 格式化的精度控制 字符串格式化 对表达式进行格式化 小练习(股票计算小程序) 数据输入 布尔类型和比较运算符 if语句 小练习(成人判断) if-else语句 if-elif-else语句 练习:猜猜心里数字 嵌套语句 猜…

JavaScript中的Array(数组)对象

目录 一、Array数组对象 1、介绍 2、创建数组对象并赋值 3、访问数组元素 二、Array对象属性 1、constructor属性 2、length属性 3、prototype属性 三、Array对象的常用方法 1、isArray() 2、concat() 3、pop() 4、shift() 5、push() 6、unshift() 7、reverse(…

前端进阶:Vue.js

目录 框架&#xff1a; 助解&#xff1a; 框架&#xff1a; VUE 什么是Vue.js? Vue.js优点 Vue安装 方式一&#xff1a;直接用<script>引入 方式二&#xff1a;命令行工具 第一个Vue程序 代码 代码解释&#xff1a; 运行 Vue指令 v-text v-html v-tex…

git 中有关 old mode 100644、new mode 10075的问题解决小结

问题&#xff1a; 同一个文件被修改后&#xff0c;最后代码没有变&#xff08;代码刚开始修改了&#xff0c;最后又删除还原了&#xff09;&#xff0c;文件变了&#xff0c;导致提交了一个空文件 git diff 提示 filemode 发生改变&#xff08;old mode 100644、new mode 1007…

RabbitMQ进阶篇

文章目录 发送者的可靠性生产者重试机制实现生产者确认 MQ的可靠性数据持久化交换机持久化队列持久化消息持久化 Lazy Queue(可配置~)控制台配置Lazy模式代码配置Lazy模式更新已有队列为lazy模式 消费者的可靠性消费者确认机制失败重试机制失败处理策略 业务幂等性唯一消息ID业…

layui-页面布局

1.布局容器 分为固定和完整宽度 class layui-container 是固定宽度 layui-fluid是完整宽度

傻瓜交换机多网段互通组网、设备无法配置网关案例

记录一下&#xff1a; 一、傻瓜交换机多网段互通组网 1、客户在核心交换机上创建了VLAN10&#xff0c;VLAN20。 VLAN10&#xff1a;IP192.168.10.254 VLAN20&#xff1a;IP192.168.20.254 在核心交换机下挂了一台傻瓜交换机&#xff0c;傻瓜交换机接入了一台OA服务器IP&#…

从零开始:在Windows上部署大型模型

这是一个超详细安装教程&#xff0c;介绍了在 Window 电脑上如何部署 Qwen1.5 大模型。本文还涉及到 Python 及其环境的配置。 适合对象&#xff1a;有点后端编程基础&#xff0c;没有 Python 基础。 需要环境&#xff1a;Window10/11&#xff0c;支持 Cuda 的 Nvidia 显卡。…

数据结构与算法-动态规划-最长回文子串

最长回文子串 给你一个字符串 s&#xff0c;找到 s 中最长的回文子串。 示例 1&#xff1a; 输入&#xff1a;s "babad" 输出&#xff1a;"bab" 解释&#xff1a;"aba" 同样是符合题意的答案。示例 2&#xff1a; 输入&#xff1a;s "…

识图ACWP.BCWS.BCWP

将三个概念想象成三个角色&#xff08;如&#xff1a;勇士、法师、盗贼&#xff09;&#xff0c;其中&#xff1a; ACWP是勇士&#xff0c;代表实际力量&#xff08;实际成本&#xff09;&#xff1b;BCWS是法师&#xff0c;代表预期魔法&#xff08;预算成本工作量预测&#x…

vscode移动侧边栏到右边

vscode移动侧边栏到右边&#xff0c;的简单办法 直接在侧栏上单击右键&#xff0c;选择向右移动主侧栏

有哪些好的 Stable Diffusion 提示词(Prompt)可以参考?

Docker 作图咒语生成器 docker-prompt-generator 是一个开源项目&#xff0c;可以利用模型反推出提示词&#xff0c;让你偷偷懒&#xff0c;无需琢磨怎么写prompt&#xff0c;只需要找一个差不多的模型反推一下&#xff0c;直接用就好了&#xff0c;支持支持 MidJourney、Stab…

Go - 9.struct 使用指南

目录 一.引言 二.struct 定义 三.struct 实践 1. 初始化 struct 2. 嵌套 struct 3. func 与 struct 四.struct 进阶 1.Json Tags 2.Other Tags 五.总结 一.引言 在编程中&#xff0c;结构体&#xff08;struct&#xff09;是一种聚合数据类型&#xff0c;用于将多个…

文献解读-长读长测序-第十四期|《作为了解棉花驯化的资源,印度棉(Gossypium herbaceum L. Wagad)基因组》

关键词&#xff1a;基因组&#xff1b;长读长测序&#xff1b;棉花基因组&#xff1b; 文献简介 标题&#xff08;英文&#xff09;&#xff1a;The Gossypium herbaceum L. Wagad genome as a resource for understanding cotton domestication标题&#xff08;中文&#xff…

【HTML入门】列表与表格

文章目录 前言一、列表与表格是什么&#xff1f;列表表格 二、使用标签列表标签表格标签 三、组合情况列表的组合表格的组合 四、示例代码总结 好的&#xff0c;以下是一个关于HTML列表与表格的文章示例&#xff1a; 前言 随着网页开发的普及&#xff0c;HTML成为了构建网页的…

零基础学习MySQL---MySQL入门

顾得泉&#xff1a;个人主页 个人专栏&#xff1a;《Linux操作系统》 《C从入门到精通》 《LeedCode刷题》 键盘敲烂&#xff0c;年薪百万&#xff01; 一、什么是数据库 问&#xff1a;存储数据用文件就可以了&#xff0c;为什么还要弄个数据库呢&#xff1f; 这就不得不提…

Java面试八股文

一、Redis 1. 使用场景 &#xff08;1&#xff09;Redis的数据持久化策略有哪些 RDB&#xff1a;全称Redis Database Backup file&#xff08;Redis数据备份文件&#xff09;&#xff0c;也被叫作Redis数据快照。简单来说就是把内存中的所有数据都记录到磁盘中。当Redis实例故…

Chapter9 更复杂的光照——Shader入门精要学习笔记

Chapter9 更复杂的光照 一、Unity的渲染路径1.渲染路径的概念2.渲染路径的类型①前向渲染路径a. 前向渲染路径的原理b. Unity中的前向渲染c. 两种Pass ②延迟渲染路径a. 延迟渲染路径的原理b. Unity中的延迟渲染c. 两种Pass ③顶点照明渲染路径 二、Unity的光源类型1.光源类型①…
最新文章