摘:DBA案例CPU占用100%的问题 天高地厚

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)更改备份计划,让备份完成后自动进行索引碎片重新组织的任务等。

不登高山,怎知天高;不临深溪,焉知地厚!站在坚实的土地上,做着生命中最真实的事情;像一棵挺拔的大树,认可自己的命运并敢于迎接属于这一方天空的风风雨雨。

原文地址:https://www.cnblogs.com/net2012/p/2823298.html