1.操作系统:排除可能是木马或病毒等。
2.应用系统:(a)重要表的索引建立和使用,(b)执行效率低的SQL导致查询或更新进程的阻塞,直至引发的死锁现象。
这都将成为引发SQL Server响应异常缓慢,CPU占用率高居不下的主要原因。
(1).首先执行sp_lock,排除X锁和IX锁。
(2).查询是否是由于重要表引起的CPU占用率高:
SELECT TOP 5 total_worker_time, last_worker_time,
max_worker_time, min_worker_time,
SUBSTRING(st.text, (qs.statement_start_offset/2) + 1,
((CASE statement_end_offset WHEN -1 THEN DATALENGTH(st.text)
ELSE qs.statement_end_offset END - qs.statement_start_offset)/2) + 1)
as statement_text
FROM sys.dm_exec_query_stats as qs
CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) as st
ORDER BY max_worker_time DESC
(3).开启SQL Server Profiler进行跟踪。
(a)通过trc文件可得知,Duration出现较大值的次数及objectType对象类型。
(b)有了trc文件,可让数据库引擎优化顾问分析并得出优化报告。
(c)择其善者而从之,执行一些重建索引和静态信息的语句等。
(d)更改备份计划,让备份完成后自动进行索引碎片重新组织的任务等。