首页 > 数据库 >面试官:MySQL死锁是什么,如何解决?

面试官:MySQL死锁是什么,如何解决?

时间:2024-07-09 17:25:54浏览次数:20  
标签:行级 事务 READ 面试官 死锁 MySQL 锁定

MySQL死锁概述

  • 定义:多个操作相互等待对方释放资源,导致无法继续执行的情况。
  • 场景:通常发生在多个事务同时试图锁定对方已锁定的资源时。

MySQL锁的分类

  • 粒度分类

    • 表级锁:锁定整个表,简单但并发能力低。
    • 行级锁:锁定特定行,开销大,可能死锁,但并发度高。
    • 页级锁:锁定数据库页,介于表级和行级之间。
  • 操作类型分类

    • 读锁(S锁):允许读取,阻止写操作。
    • 写锁(X锁):排他锁,阻止其他事务读写。
  • 意向锁:表明事务对数据行加锁的意图。

  • 性能分类

    • 乐观锁:假设冲突少,通过版本号或时间戳检查冲突。
    • 悲观锁:假设冲突多,保持数据锁定直到事务完成。

InnoDB存储引擎行锁模式

  • 记录锁:锁定具体数据,防止其他事务修改。
  • 间隙锁:锁定范围但不包括记录,解决幻读问题。
  • 临键锁:结合记录锁和间隙锁,锁定记录及其前空隙。

事务隔离级别与锁的关系

  • 隔离级别:READ UNCOMMITTED, READ COMMITTED, REPEATABLE READ, SERIALIZABLE。
  • MySQL默认:可重复读(REPEATABLE READ)。
  • 隔离级别与锁:封装了锁机制和MVCC技术,简化并发控制。

死锁产生原因和解决方案

  • 表级锁死锁:不同事务按不同顺序锁定资源。

    • 解决方案:保持一致的锁定顺序,避免同时锁定两个资源。
  • 行级锁死锁

    • 原因1:无索引条件查询导致全表扫描,行锁膨胀为表锁。
    • 原因2:事务互相等待对方持有的锁。
    • 解决方案:优化SQL语句,建立索引,避免复杂关联查询。

预防死锁优化实践

  1. 维持一致的锁定顺序。
  2. 使用最小的锁粒度,优先使用行级锁。
  3. 减少事务持续时间,优化查询语句。
  4. 使用锁超时,自动回滚等待超时的事务。
  5. 死锁检测和回滚,数据库自动检测并解决死锁。
  6. 避免不必要的锁,审查和优化事务逻辑。
  7. 使用乐观并发控制,适用于读多写少的场景。
  8. 避免无索引行锁升级为表锁,确保数据检索通过索引完成。
  9. 监控和日志记录,跟踪死锁和性能瓶颈。

总结

  • 解决死锁:通过日志分析找到死锁并处理。
  • 分析死锁原因:优化以避免死锁再次发生。

标签:行级,事务,READ,面试官,死锁,MySQL,锁定
From: https://blog.csdn.net/modelsetget/article/details/140301822

相关文章

  • MySQL 源码|LEX 结构体
    LEX结构体源码位置:(版本=MySQL8.0.37)sql/sql_lex.hsql/sql_lex.ccsql/sql_class.ccrouter/src/routing/src/sql_lexer.ccLEX对象当前有以下功能:包含了一些SQL命令的通用属性,例如:sql_command,数据变更语句语法中是否存在IGNORE,以及表列表query_tables包含了一些......
  • Mysql更新数据库密码
    首先登录数据库mysql-uroot-p1234qwer查找数据库用户表所有用户信息SELECT`Host`,`User`,authentication_string,password_last_changedFROMmysql.`user`;更新密码UPDATEmysql.`user`SETauthentication_string=PASSWORD('1234qwert')WHEREuser='root'AND......
  • MYSQL——mysql检索不包含字母U的数据
    2024/07/091.NOTLIKE2.ISNOT、<>、!=3.NOTIN如题,正确答案如下:SELECT*FROMyour_table_nameWHEREyour_column_nameNOTLIKE'%U%';今天写类似检索语句时,脑子突然一懵,写成了ISNOT'%UD%',如下:SELECT*FROMyour_table_nameWHEREyour_column_nameISNOT......
  • Mysql主从复制
    一、主从复制原理主从复制的相关程序:日志二进制日志中继日志(relaylog)线程主服务器:mysqldump线程(传输二进制日志给从服务器)从服务器:IO线程(接收二进制日志,写入中继日志),sql线程(读取中继日志,写入数据库,同步操作达到数据同步)点击查看代码主从复制原理:1.主节点负责......
  • mysql集群高可用架构MHA
    一、MHA概述1.为什么要用MHAMaster的单点故障问题2.什么是MHAMHA(MasterHighAvailability)是一套优秀的MySQL高可用环境下故障切换和主从复制的软件。MHA的出现就是解决MySQL单点的问题。MySQL故障切换过程中,MHA能做到0-30秒内自动完成故障切换操作。MHA能在故障切换的过程......
  • 快速上手:前后端分离开发(Vue+Element+Spring Boot+MyBatis+MySQL)
    文章目录前言项目简介环境准备第一步:初始化前端项目登录页面任务管理页面第二步:初始化后端项目数据库配置数据库表结构实体类和Mapper服务层和控制器第三步:连接前后端总结......
  • MySQL8.0索引新特性
    文章目录1支持降序索引2隐藏索引1支持降序索引举例:分别在MySQL5.7版本和MySQL8.0版本中创建数据表ts1,结果如下:CREATETABLEts1(aint,bint,indexidx_a_b(a,bdesc));在MySQL5.7版本中查看数据表ts1的结构,从结果可以看出,索引仍然是默认......
  • 九,MYSQL之存储过程,实际就是用slq写函数,封装方法
    目录一,概念    1,介绍.    2,特性    3,作用二,格式    简单的存储过程案例基本格式:三,变量    1,局部变量        2,变量赋值     3,会话变量 3,系统变量四,参数    1,in参数   ......
  • 十三,mysql的优化,详细篇
    目录一,从设计上优化二,从查询上优化三,从索引上优化四,从存储上优化一,从设计上优化    1,合理的进行数据库设计,通过规范化设计可以避免数据冗余,也可以适当的反规范化设计提高查询性能.    2,选择合适的数据类型,确保使用最合适的数据类型来存......
  • mysql注入总结
    1.SQL注入漏洞概述什么是SQL注入SQL注入(SQLi)是一种网络安全漏洞,允许攻击者干扰应用程序对其数据库的查询。通过浏览器或者其他客户端将恶意SQL语句插入到网站参数中,而网站应用程序未对其进行过滤,SQL语句带入数据库使恶意SQL语句得以执行可以查看通常无法检索的数据。这可能包括......