死锁是多个事务相互等待对方释放锁导致的僵局,MySQL会自动回滚一事务打破循环。常见原因包括加锁顺序不一致、全表扫描、长事务等。通过SHOW ENGINE INNODB STATUS可查看最近死锁详情,定位冲突SQL。避免措施有:统一加锁顺序、缩短事务时间、使用索引、合理设置隔离级别。应用层应捕获错误码1213,实现有限重试并记录日志。死锁无法完全避免,需通过设计优化和监控降低影响。
MySQL事务中的死锁是多个事务相互等待对方释放资源锁,导致彼此无法继续执行的情况。系统检测到死锁后会自动回滚其中一个事务以打破循环等待,但作为开发者或DBA,需要理解其成因并采取措施减少发生频率。
死锁通常出现在多个事务以不同顺序访问相同的资源(如表、行)并加锁时。典型场景包括:
用不一致,导致加锁顺序不同MySQL提供SHOW ENGINE INNODB STATUS命令,可查看最近一次死锁的详细信息:
操作示例:
SHOW ENGINE INNODB STATUS\G输出中LATEST DETECTED DEADLOCK部分会显示两个事务的SQL语句、锁等待状态、回滚建议等,帮助定位问题SQL和加锁顺序。
虽然MySQL能自动处理死锁,但频繁死锁会影响业务。可通过以下方式降低发生概率:
当MySQL回滚事务时,会抛出Deadlock found when trying to get lock错误。应用应:
基本上就这些。死锁无法完全避免,关键是通过设计减少概率,并在发生时妥善处理。监控和分析死锁日志是优化数据库行为的重要手段。