我们在我们的sql Server 2005群集上发生零星随机查询超时.我拥有使用它的几个应用程序,所以我正在帮助调查.当您在常规的“Perfmon”中观察%cpu时间时,您可以看到它与之挂钩.但是,sql活动监视器仅给出进程使用的累积cpu和IO时间,而不是在特定时间段内使用的cpu时间和IO时间.也许我可以使用分析器并运行一个跟踪,但是这个集群是非常重要的使用,我恐怕我会在干草堆里寻找一个针.我正在树上错误的树吗?
解决方法
这将为您提供平均cpu时间的前50名报表,请查看其他脚本:
http://www.microsoft.com/technet/scriptcenter/scripts/sql/sql2005/default.mspx?mfr=true
SELECT TOP 50 qs.total_worker_time/qs.execution_count as [Avg cpu Time],SUBSTRING(qt.text,qs.statement_start_offset/2,(case when qs.statement_end_offset = -1 then len(convert(nvarchar(max),qt.text)) * 2 else qs.statement_end_offset end -qs.statement_start_offset)/2) as query_text,qt.dbid,dbname=db_name(qt.dbid),qt.objectid FROM sys.dm_exec_query_stats qs cross apply sys.dm_exec_sql_text(qs.sql_handle) as qt ORDER BY [Avg cpu Time] DESC