好学IT学院:IT信息技术分享交流平台
来源:互联网  作者:佚名  发布时间:2008-03-28  ★★★加入收藏〗〖手机版
摘要:打开SQL中的查看进程信息,发现里面有90个进程,大部份都处于sleeping状态,请问这样会影响服务器性能吗?要怎么取消呢?通过以下方法查询没有释放的链接,得到的记录为0============================================…

打开SQL中的查看进程信息,发现里面有90个进程,大部份都处于sleeping状态,请问这样会影响服务器性能吗?要怎么取消呢?  
  通过以下方法查询没有释放的链接,得到的记录为0  
  ===============================================  
  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())  
  ==================================================


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   '?'   
    
  这个方法也没有办法杀掉sleeping状态的进程

  • 好学触屏公众号虎力全开、杨帆起航!
  • 好学考试H5触屏版开放内测