• 技术文章 >数据库 >mysql教程

    mysql死锁是什么意思

    VV2020-06-24 15:28:50原创1058

    mysql死锁是指两个或多个事务在同一资源上相互占用,并请求锁定对方占用的资源,从而导致恶性循环。InnoDB存储引擎能检测到死锁的循环依赖并立即返回一个错误。只有部分或完全回滚其中一个事务,才能打破死锁。

    什么是死锁?它是如何产生的?

    死锁是指两个或多个事务在同一资源上相互占用,并请求锁定对方占用的资源,从而导致恶性循环。

    (推荐教程:mysql教程

    当事务试图以不同的顺序锁定资源时,就可能产生死锁。多个事务同时锁定同一个资源时也可能会产生死锁。

    锁的行为和顺序和存储引擎相关。以同样的顺序执行语句,有些存储引擎会产生死锁有些不会——死锁有双重原因:真正的数据冲突;存储引擎的实现方式。

    检测死锁

    数据库系统实现了各种死锁检测和死锁超时的机制。InnoDB存储引擎能检测到死锁的循环依赖并立即返回一个错误。

    死锁恢复

    死锁发生以后,只有部分或完全回滚其中一个事务,才能打破死锁。

    InnoDB目前处理死锁的方法是,将持有最少行级排他锁的事务进行回滚。所以事务型应用程序在设计时必须考虑如何处理死锁,多数情况下只需要重新执行因死锁回滚的事务即可。

    以上就是mysql死锁是什么意思的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:mysql 死锁
    上一篇:mysql有哪些常见的存储引擎 下一篇:mysql隔离级别有几种
    大前端线上培训班

    相关文章推荐

    • 死锁的概念与死锁的条件• mysql死锁是怎么造成的• 怎么样避免mysql死锁• mysql死锁怎么解决?

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网