如何识别SQL Server中的CPU瓶颈

系统 1822 0
原文: 如何识别SQL Server中的CPU瓶颈

原文出自:

http://www.mssqltips.com/sqlservertip/2316/how-to-identify-sql-server-cpu-bottlenecks/

 

问题:

如果经常遇到CPU瓶颈而导致的SQLServer宕机,那如何去发现并解决这些相关的问题?

 

解决方案:

导致CPU成为SQLServer性能问题的原因有很多,比较明显的原因是因为资源不足。但是,CPU的利用率可以通过配置的更改和查询的优化来降低,所以当你想买更快更好的处理器之前,先要考虑前面的操作。下面是使用一些内置工具来识别CPU相关瓶颈:

 

性能监视器(Performance Monitor):

可以使用性能监视器来检查CPU的负载。检查 Processor:% Processor Time 这个计数器:如果长期超过80%/处理器,那很有可能面临了CPU相关瓶颈。

 

CPU密集操作主要是编译和重编译。你可以通过使用SQL Statistics对象计数器来监视它们的情况。也可以监控批处理接收的数量来查看。如果 SQL Recompilations/sec 中的 BatchRequests/sec 的速率很高,那就有潜在的问题:

配置和监视以下计数器:

  • SQL Server: SQL Statistics: SQL Compilations/sec
  • SQL Server: SQL Statistics: SQL Recompilations/sec
  • SQL Server: SQL Statistics: Batch Requests/sec

可以从MSDN中获取关于这部分的详细信息:  MSDN Library .

 

另外一个用于探测CPU相关问题的计数器是: SQL Server: Cursor Manager By Type – CursorRequests/Sec ,用于显示你的服务器上游标使用情况。如果你看到每秒有数以百计的游标请求,那很有可能是因为低效的游标使用和小体积提取操作(small fetch size)引起性能问题。

 

内部并行查询同样会引起CPU问题,可以检查:

SQL Statistics:Batch Requests/sec  counter 计数器。在CPU生命周期中,每秒的批处理应该很小。如果过多,意味着正在使用并行计划运行。

 

动态管理视图(DMVs):

以下是对排查CPU瓶颈游泳的DMVs。动态视图:sys.dm_exec_query_stats显示目前缓存的批处理或者使用CPU的过程。下面的查询用于检查耗费CPU的执行计划:

select plan_handle,

      sum(total_worker_time) as total_worker_time,

      sum(execution_count) as total_execution_count,

      count(*) as number_of_statements

from sys.dm_exec_query_stats

group by plan_handle

order bysum(total_worker_time), sum(execution_count) desc

 

SQLServer2008在每个查询编译时,会计算其hash值。你可以在query_hash列中找到该值,是否两个查询仅仅字面值不同但是使用相同query_hash值。该值也在  Showplan/Statistics XML  QueryHash属性中可以查看。

Plan_generation_num列显示一个查询被重编译的次数。

SQLServer优化器尝试选择能提供最快响应时间的执行计划,但是不代表总是低CPU利用。低效的查询计划会引起CPU的好用,此时同样可以使用 sys.dm_exec_query_stats 来监控。

如果你想有一个对SQLServer优化所耗费时间的总览,可以检查:

sys.dm_exec_query_optimizer_info 。其中的消耗时间和最后开销会非常有用。

可以使用以下DMVs来查询内部并行查询及其查询文本、执行计划的情况:

  • sys.dm_exec_cached_plan Shows the cached query plans.
  • sys.dm_exec_requests Shows each executing request in the SQL Server instance.
  • sys.dm_exec_sessions Shows all active user connections and internal tasks.
  • sys.dm_exec_sql_text Shows the text of the SQL batches.
  • sys.dm_os_tasks Shows each active task within SQL Server.

 

SQL Server Profiler:

如果性能监视器发现有问题,同样可以使用SQLServer Profiler来发现不必要的编译和重编译。SQLServer Profiler 跟踪能帮助你找到一直重编译的存储过程。可以使用下面的事件:

  • SP:Recompile CursorRecompile SQL:StmtRecompile : 这个事件是针对SQLServer的重编译。 SP:Recompile 事件中的 EventSubClass 说明了重编译的原因。

·         Showplan XML For Query Compile : 这个事件是针对T-SQL语句的重编译。包含了查询计划和过程的对象ID.注意对这个事件运行一个跟踪,能得到利用系统资源的重要信息。但是,如果性能计数器报告 SQL Compilations/sec 的值很高时,跟踪将非常好资源。

低效的游标可以使用RPC:Completed事件来跟踪。查看sp_cursorfetch语句并检查第四个参数,包含每次提前(fetch)包含的行数。

 

如何识别SQL Server中的CPU瓶颈


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论