关于SQL中的进程信息

来源:互联网  作者:佚名
摘要:打开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状态的进程

【相关文章】好搜一下
韩国宽带网速全球最快!中国名列77位

韩国宽带网速全球最快!中国名列77位

近日美国互联网流量监测机构Ookla发布了最新的全球宽带服务统计数据,该报告显示…