最近应用程序中老是报:
[IBM][CLI Driver][DB2/6000] SQL0911N 因为死锁或超时,当前事务已被回滚。原因码为 "68"。 SQLSTATE=40001
或者是
[IBM][CLI Driver][DB2/6000] SQL0911N 因为死锁或超时,当前事务已被回滚。原因码为 "2"。 SQLSTATE=40001
以下是我查找原因和解决问题的方法和步骤,与大家共享。
1.调整数据库参数 LOCKLIST,MAXLOCKS,LOCKTIMEOUT,DLCHKTIME
参数说明:
LOCKLIST就是锁资资源大小,实际上就是以KB为单位的内存。
MAXLOCKS是一个应用程序实际使用的锁资源所占用的LOCKLIST的比例,当超过这个比例时,锁就会产生升级。
LOCKTIMEOUT锁等待超时时间,以秒为单位。当应用程序提出所资源申请时,如果超过了这个时间而没有得到就会产生锁定超时。
DLCHKTIME是检测死锁的时间间隔,以毫秒为单位。
增大LOCKLIST.
首先查看数据库参数 get db cfg for database,
得到
LOCKLIST 1000
MAXLOCKS 90
LOCKTIMEOUT 45
DLCHKTIME 60000
LOCKLIST好像有些小,二话不说讲参数修改为10000后进行观察,错误出现的频率小了,问题还是存在,咬咬呀狠狠心改为30000
呵呵,终于不出现了,我也清闲了一段时间。可是好几景不长大约过了一个月左右的时间,问题又出现了。郁闷ing。
2.利用控制中心查找有问题的SQL.
使用控制中心的监控器可以非常方便的找到是否有死锁,应用程序锁等待数量、时间,锁升级等情况。
3.查看数据库的db2diag.log和db2inst.nfy
通过检查db2inst.nfy发现
006-08-07-16.51.22.475742 Instance:db2inst Node:000
PID:53740(db2agent (DB) 0) TID:1 Appid:C0A8003A.KD70.00CAC7083407
data management sqldEscalateLocks Probe:3 Database B
ADM5502W The escalation of "270083" locks on table "OWN .POST_GOODS" to
lock intent "S" was successful.
在POST_GOODS要有170083个锁啊,于是怀疑与POST_GOODS有关的应用有问题了。
4.让开发人员找到对应的SQL一看,我差点晕倒了。My god这儿居然没有任何条件。让开发人员根据业务需要增加查询条件。再重新发布应用,测试哈哈,不仅应用程序飞快,并且不在出现[IBM][CLI Driver][DB2/6000] SQL0911N 因为死锁或超时,当前事务已被回滚。原因码为 "68"。 SQLSTATE=40001
或者是
[IBM][CLI Driver][DB2/6000] SQL0911N 因为死锁或超时,当前事务已被回滚。原因码为 "2"。 SQLSTATE=40001
5.修改数据库参数
问题的根本原因找到了,数据库参数也要调整一下, 将LOCKLIST修改为20000,太大了也不好!如果一个应用使用的锁资源超过了20000*90,这个应用程序本身肯定有问题了
- 浏览: 422339 次
- 性别:
- 来自: 北京
最新评论
-
masuweng:
好好好,有时间了练习下
使用Java混淆工具yguard -
shengshihouzhe:
第一个eg实现的应该是循环栅栏,不是计数器
Java Phaser使用 -
yukaizhao:
推荐一个很全的guava教程 http://outofmemo ...
google guava cache 处理 -
yanqingluo:
谢谢分享,已关注.
BTrace入门及使用实例 -
luoxiaohui_java:
谢谢分享!
这么好的文章,怎么没人回复呢。
ibm was nd websphere 集群
相关推荐
在SQL Server数据库管理系统中,死锁是常见的并发问题,它发生在两个或多个事务相互等待对方释放资源,导致它们都无法继续执行。"SQLServer自动杀死死锁进程"这一话题旨在探讨如何配置SQL Server来自动检测并解决...
在SQL Server数据库管理系统中,死锁是一个常见的性能问题,它发生在两个或多个事务相互等待对方释放资源,导致它们都无法继续执行。死锁不仅影响数据库的正常运行,还可能导致数据一致性问题。本文将详细介绍如何在...
SQL Server死锁是数据库系统中常见的问题,它发生在两个或多个事务之间,因为它们相互等待对方释放资源,导致事务无法继续执行。理解死锁的原因和解决策略对于优化数据库性能至关重要。 首先,我们要深入理解死锁的...
本过程自动捕捉SQLSERVER中的死锁进程并且自动杀掉
SQL server大并发时软件出现卡顿,需要查询是什么SQL执行时引起的卡顿,同时具有干掉死锁进程,非常实用
SQL 表死锁是指在 SQL Server 中,一个或多个进程无法访问某个表或库,因为这些进程都在等待某个资源,而这个资源又被其他进程占用着。这种情况下,SQL Server 会超时,导致表或者库不可访问。 二、如何找到死锁的...
因此,解决SQL Server死锁是非常重要的。 SQL Server死锁的查询方法有多种,下面列举了几种常见的方法: 1. 使用exec master..xp_lockinfo 0, 0命令来查询死锁的进程信息。 2. 使用exec master..xp_lockinfo 1, 0...
- **死锁超时**:SQL Server默认设置了一个死锁超时阈值,当达到这个阈值,数据库引擎会选择一个死锁链中的“牺牲品”(受害者)事务,结束该事务并回滚,以打破死锁。 - **手动干预**:通过`KILL`命令强制终止...
本文将深入探讨“sql数据库死锁查询工具”及其在解决数据库死锁和阻塞过程中的作用。 **1. SQL死锁** SQL死锁是指两个或多个事务在执行过程中,因争夺资源而造成的一种相互等待的现象,若无外力干涉,它们都将无法...
### SQL Server 死锁排查与解决方法 #### 一、SQL Server Profiler 监控数据库死锁 在处理SQL Server数据库中的死锁问题时,一个非常实用的工具就是SQL Server Profiler。它可以帮助我们捕捉到数据库运行过程中的...
### SQL死锁解析与删除失败解决方案 #### 一、理解SQL死锁 在数据库系统中,当两个或多个事务在等待对方释放资源时就会发生死锁。这种情况类似于现实生活中的两个或多个人互相等待对方做出动作而自己却不动的情况...
在SQL Server 2005中,死锁是数据库系统中常见的问题,通常发生在两个或多个事务互相等待对方释放资源时。这种情况下,数据库管理系统会选择牺牲其中一个事务来解除死锁状态,即回滚该事务并抛出一个错误。SQL ...
在SQL Server数据库管理中,死锁是一个常见的性能问题,它发生在两个或多个事务相互等待对方释放资源时。本文将深入探讨如何使用SQL Server Profiler工具来监视和分析死锁,以便更好地理解和解决这类问题。 首先,...
为了有效地管理死锁,SQL Server提供了多种工具和技术来帮助开发者和DBA识别和解决死锁问题。 #### SQL Server 死锁检测存储过程 在提供的代码中,我们看到一个名为`sp_who_lock`的存储过程,用于检测SQL Server中...
在SQL Server数据库管理中,死锁是一个常见的问题,它发生在两个或多个事务相互等待对方释放资源,从而导致所有事务都无法继续执行的情况。SQL Server提供了多种工具和方法来检测和分析死锁,以便管理员能够及时发现...
这对于诊断和解决SQL Server中的死锁问题非常有帮助。此外,它还展示了如何使用SQL Server的系统表、函数和命令来实现这一目标。对于SQL Server管理员和开发人员来说,掌握这样的工具和技术是非常重要的。
### 解决SQL死锁问题 #### 一、SQL死锁概念与原理 SQL死锁是数据库操作中一种常见的并发控制问题。当两个或多个事务在等待对方释放资源时,就会形成死锁。在Oracle数据库中,死锁可能导致部分或者全部数据库操作...
此代码运行后,会生成一个存储过程,后面直接调用此存储过程即可查看,运行非常方便,可以快速定位死锁进程,快速解决sql数据库死锁问题。希望可以给各位系统管理员带来方便。希望可以给各位系统管理员带来方便。...