Sql进程问题


1.   如果条件许可,   首先把iis和sql   server分到两台服务器中,   这样可以避免两者互相影响,   也有利于查找直接的原因.(例如,   由于IIS工作缓慢,   可能会导致不断的向sql发请求,   这样看起来似乎就是sql   server的问题)         2.   如果要查询是否连接没有释放引起的,   你可以用查询分析器连接到你的数据库服务器,   执行下面的代码:     select   *   from   master.dbo.sysprocesses     where   spid>50     and   waittype   =   0x0000     and   waittime   =   0     and   status   =   'sleeping'     and   last_batch   <   dateadd(minute,   -10,   getdate())     and   login_time   <   dateadd(minute,   -10,   getdate())         如果这样的进程很多,   则说明连接确实有很多连接没有释放(上面的查询查询出已经超过10分钟都没有做任何动作的连接)             3.   如果确实是连接没有释放的问题,   你可以硬行释放连接,   不一定要改程序.   在sql   server中,   创建一个job,   每10分钟一次,   执行下面的代码来定时检查并释放掉空连接就可以了:     declare   hcforeach   cursor   global     for     select   'kill   '   +   rtrim(spid)   from   master.dbo.sysprocesses     where   spid>50     and   waittype   =   0x0000     and   waittime   =   0     and   status   =   'sleeping'     and   last_batch   <   dateadd(minute,   -60,   getdate())     and   login_time   <   dateadd(minute,   -60,   getdate())     exec   sp_msforeach_worker   '?'  

posted @ 2007-04-29 17:33  spring3  阅读(182)  评论(0编辑  收藏  举报