DB2 SQL0911N

SQL0911N The current transaction has been rolled back because of a deadlock or timeout. Reason code "68".

SQL0911N  因为死锁或超时,所以当前事务已回滚。原因码为 "68"。

性能测试时出现此问题,开始以为是死锁,后来查到出现SQL0911N 并非一定是死锁,还取决于原因码是哪一个。

SQL0911N  因为死锁或超时,所以当前事务已回滚。原因码为 "<原因码>"。

说明:
当前工作单元参与了未解决的对象争用,因此必须回滚。

原因码如下所示:

2        由于死锁而导致事务已回滚。

68       由于锁定超时而导致事务已回滚。

72       因为存在与事务中所涉及的 DB2 Data Links Manager 有关的错误,所
         以事务已回滚。

注: 必须再次输入与工作单元相关的更改。
应用程序已回滚至上一次 COMMIT。

本人遇到的错是锁等待超时而并非死锁。当然锁等待超时也意味着存在性能问题。

锁等待超时解决办法:
1.优化相关sql
2.延长超时设置合适大小

死锁分析方法:
db2对死锁进行分析需借助死锁监视器,但打开死锁监视器会有额外的开销,一般情况下禁用死锁监视器。
具体操作可见官网https://www.ibm.com/developerworks/cn/data/library/techarticles/dm-1004lockeventmonitor/

猜你喜欢

转载自blog.csdn.net/qq_30599553/article/details/85008298