首页  >> 配置管理  >> IBM Rational ClearQuest / ClearDDTS/TestManager
SQL死锁如何解决
作者 ljs53   查看 449   发表时间 2008/7/5 13:21  【论坛浏览】
最近我们公司的clearquest在进行操作的时候经常出现无响应的时候rjqliks
然后发现原数据库因是由于SQL2000死锁造成的rjqliks
目前我们公司的环境是 clearquest 2002.05.00 rjqliks
SQL2000数据库 rjqliks
用户大概有100人左右rjqliks
rjqliks
在网上查找了一些方法 都没有奏效rjqliks
不知道大家有没有遇到过此类问题 后来是如何解决的

序号 评论者 共有评论 5   【论坛浏览】  【发表评论】 评论时间
1 听雨屋檐人

  引用:
原帖由 ljs53 于 2008-7-5 13:21 发表
最近我们公司的clearquest在进行操作的时候经常出现无响应的时候
然后发现原数据库因是由于SQL2000死锁造成的
目前我们公司的环境是 clearquest 2002.05.00
SQL2000 ...

曾经关注过这个问题,下面是我再网上找到的方法,可以参考这个自己写个脚本用于检测是否有死锁!如果存在死锁就杀掉,当然这是防御措施,最好还是要从根源处解决问题,你可以看看自己的cq hook是否有问题,sp4是否已经更新,并发处理是否有问题等!

  代码:

use master --必须在master数据库中创建
go

if exists (select * from dbo.sysobjects where id = object_id(n[dbo].[p_lockinfo]) and objectproperty(id, nisprocedure) = 1)
drop procedure [dbo].[p_lockinfo]
go

/*--处理死锁

查看当前进程,或死锁进程,并能自动杀掉死进程

因为是针对死的,所以假如有死锁进程,只能查看死锁进程
当然,您能够通过参数控制,不管有没有死锁,都只查看死锁进程

感谢: caiyunxia,jiangopen 两位提供的参考信息

--邹建 2004.4--*/

/*--调用示例

exec p_lockinfo
--*/
create proc p_lockinfo
@kill_lock_spid bit=1, --是否杀掉死锁的进程,1 杀掉, 0 仅显示
@show_spid_if_nolock bit=1 --假如没有死锁的进程,是否显示正常进程信息,1 显示,0 不显示
as
declare @count int,@s nvarchar(1000),@i int
select id=identity(int,1,1),标志,
进程id=spid,线程id=kpid,块进程id=blocked,数据库id=dbid,
数据库名=db_name(dbid),用户id=uid,用户名=loginame,累计cpu时间=cpu,
登陆时间=login_time,打开事务数=open_tran, 进程状态=status,
工作站名=hostname,应用程式名=program_name,工作站进程id=hostprocess,
域名=nt_domain,网卡地址=net_address
into #t from(
select 标志=死锁的进程,
spid,kpid,a.blocked,dbid,uid,loginame,cpu,login_time,open_tran,
status,hostname,program_name,hostprocess,nt_domain,net_address,
s1=a.spid,s2=0
from master..sysprocesses a join (
select blocked from master..sysprocesses group by blocked
)b on a.spid=b.blocked where a.blocked=0
union all
select |_牺牲品_>,
spid,kpid,blocked,dbid,uid,loginame,cpu,login_time,open_tran,
status,hostname,program_name,hostprocess,nt_domain,net_address,
s1=blocked,s2=1
from master..sysprocesses a where blocked<>0
)a order by s1,s2

select @count=@@rowcount,@i=1

if @count=0 and @show_spid_if_nolock=1
begin
insert #t
select 标志=正常的进程,
spid,kpid,blocked,dbid,db_name(dbid),uid,loginame,cpu,login_time,
open_tran,status,hostname,program_name,hostprocess,nt_domain,net_address
from master..sysprocesses
set @count=@@rowcount
end

if @count>0
begin
create table #t1(id int identity(1,1),a nvarchar(30),b int,eventinfo nvarchar(255))
if @kill_lock_spid=1
begin
declare @spid varchar(10),@标志 varchar(10)
while @i<=@count
begin
select @spid=进程id,@标志=标志 from #t where id=@i
insert #t1 exec(dbcc inputbuffer(+@spid+))
if @标志=死锁的进程 exec(kill +@spid)
set @i=@i+1
end
end
else
while @i<=@count
begin
select @s=dbcc inputbuffer(+cast(进程id as varchar)+) from #t where id=@i
insert #t1 exec(@s)
set @i=@i+1
end
select a.*,进程的sql语句=b.eventinfo
from #t a join #t1 b on a.id=b.id
end
go

2008/7/5 16:17
2 softfly 我不是很清楚SS2K上是否有DEADLOCK MONITOR
但是我知道DB2上有
我建议你用同样的SCHEMA在DB2上建立一个USER DB
然后实用API来并发的POPUATE DATA
这样可以发现DEAD LOCK ISSUE
2008/7/5 21:44
3 ljs53 回复 沙发 的帖子
怎么查看并发处理有问题??
SP4是否有更新 是不是说SQL2000是否打上了SP4的补丁
2008/7/9 13:10
4 ljs53 现在出现问题的时候很多都是在modify状态下
向文本框写入内容的时候 就死锁了
2008/7/9 13:12
5 ljs53 现在终于解决了
把CQ的服务器端和所有用户的客户端都升级到7.0.1版本就可以了
具体原因不知道为什么
2008/8/6 08:35
 共有评论数 5  每页显示 10
页码 1/1  |<  <<   1   >>  >|