博客
关于我
线上频出MySQL死锁问题!分享一下自己教科书般的排查和分析过程!
阅读量:680 次
发布时间:2019-03-17

本文共 406 字,大约阅读时间需要 1 分钟。

模拟项目源码

为了模拟真实场景中的方法调用(消息接收调用执行),使用了线程来模拟。并且使用线程睡眠来保证每个事务执行够长,来让每次模拟执行都必现异常。

项目结构比较简单, Controller > Manager > Service > Mapper > DB,执行 curl 'localhost:8080/test/consumer' 后,查看命令行输出即可看到业务异常日志。

对应的死锁日志需要到对应的数据库执行 show engine innodb status 后可看到。

中间查阅了很多资料,发现有个项目总结了所有的死锁日志对应的可能 SQL:https://github.com/aneasystone/mysql-deadlocks,里面也讲解了加锁的各个细节过程,是非常值得一看的。

当遇到复杂的业务场景,尤其是不熟悉的时候,这个是一个很好的参考资料。

业务日志记录、全链路跟踪是非常非常重要的

转载地址:http://uqyhz.baihongyu.com/

你可能感兴趣的文章
Objective-C实现合并两个列表算法(附完整源码)
查看>>
Objective-C实现合并两棵二叉树算法(附完整源码)
查看>>
Objective-C实现合并拼接字符串(附完整源码)
查看>>
Objective-C实现后缀表达式(附完整源码)
查看>>
Objective-C实现后缀表达式(附完整源码)
查看>>
Objective-C实现向量叉乘(附完整源码)
查看>>
Objective-C实现命令模式(附完整源码)
查看>>
Objective-C实现和Lua互传结构体(附完整源码)
查看>>
Objective-C实现哈密顿环(附完整源码)
查看>>
Objective-C实现哈希查找(附完整源码)
查看>>
Objective-C实现哈希表算法(附完整源码)
查看>>
Objective-C实现哈里斯角检测|Harris Corner算法(附完整源码)
查看>>
Objective-C实现哥德巴赫猜想(附完整源码)
查看>>
Objective-C实现哥德巴赫猜想(附完整源码)
查看>>
Objective-C实现哥德巴赫猜想(附完整源码)
查看>>
Objective-C实现唯一路径问题的动态编程方法的算法(附完整源码)
查看>>
Objective-C实现唯一路径问题的回溯方法的算法(附完整源码)
查看>>
Objective-C实现四叉树(附完整源码)
查看>>
Objective-C实现四舍五入(附完整源码)
查看>>
Objective-C实现四舍五入(附完整源码)
查看>>