在哪种情况或场景中,sql server的cpu内存使用率如此之高?
这是一个很广泛的问题,但在这里是为了我将检查的东西..
是否有托管在同一个盒子的任何应用程序以外SQLServer的..?如果是尽量避免他们,因为这也不会下落入最佳实践..
基本故障排除,开始时,当SQLServer是用巨大的CPU,找出顶级CPU消费查询..
这可以使用下面的查询中找到,也可以使用Glen Berry DMV的特定版本使用的是..
SELECT TOP 20
qs.sql_handle,
qs.execution_count,
qs.total_worker_time AS Total_CPU,
total_CPU_inSeconds = --Converted from microseconds
qs.total_worker_time/1000000,
average_CPU_inSeconds = --Converted from microseconds
(qs.total_worker_time/1000000)/qs.execution_count,
qs.total_elapsed_time,
total_elapsed_time_inSeconds = --Converted from microseconds
qs.total_elapsed_time/1000000,
st.text,
qp.query_plan
from
sys.dm_exec_query_stats as qs
CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) as st
cross apply sys.dm_exec_query_plan (qs.plan_handle) as qp
ORDER BY qs.total_worker_time desc
下一步是尝试优化这些查询......记住一个查询就可以使用较高的CPU,当
1.没有适用吃了索引,所以它每次读取整个表..
2.Indexes是有的,但你也面临内存压力,这可能会导致缓冲池被刷新了..