扫码关注官方订阅号
即在语言级别就判断出死锁了,然后我就进行rollback,然后再次调起事务。
这套流程如何用程序语言实现? PHP
拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...
MySQL打开innodb lock monitor,innodb_status_output_locks = ON
innodb_status_output_locks = ON
PHP连上MySQL
定时执行SHOW ENGINE INNODB STATUS
SHOW ENGINE INNODB STATUS
从结果中找到deadlok的会话ID
kill掉会话,事务就回滚了
因为这个方法是从外部监听死锁,你的程序要处理会话被杀产生的异常,然后重试事务。
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
MySQL打开innodb lock monitor,
innodb_status_output_locks = ONPHP连上MySQL
定时执行
SHOW ENGINE INNODB STATUS从结果中找到deadlok的会话ID
kill掉会话,事务就回滚了
因为这个方法是从外部监听死锁,你的程序要处理会话被杀产生的异常,然后重试事务。