如何检查SQL Server CPU瓶颈

简介: --检测CPU压力的一个方法是计算运行状态下的工作进程数量,--通过执行如下的DMV查询可以得到这个信息 SELECT COUNT(*) AS workers_waiting_for_cpu,t2.

--检测CPU压力的一个方法是计算运行状态下的工作进程数量,
--通过执行如下的DMV查询可以得到这个信息

 
 
SELECT COUNT ( * ) AS workers_waiting_for_cpu,t2.scheduler_id
FROM sys.dm_os_workers AS t1, sys.dm_os_schedulers AS t2
WHERE t1.state = ' RUNNABLE ' AND
t1.scheduler_address
= t2.scheduler_address AND
t2.scheduler_id
< 255
GROUP BY t2.scheduler_id

--也可以执行如下的查询得到工作进程在可运行状态下花费的时间

SELECT SUM(signal_wait_time_ms) FROM sys.dm_os_wait_stats

--下面是一个DMV查询,它可以用来找出每次执行中占用CPU最多的钱10为查询,
--也列出了SQL语句的查询计划及计划被执行的次数。如果一个查询大家虽高,
--但执行次数少,那也可以采纳。

 
 
SELECT TOP 10
total_worker_time
/ execution_count AS avg_cpu_cost, plan_handle,execution_count,
(
SELECT SUBSTRING ( text ,statement_start_offset / 2 + 1 ,
(
CASE WHEN statement_end_offset =- 1
THEN LEN ( CONVERT ( NVARCHAR ( max ), text )) * 2
ELSE statement_end_offset
END - statement_start_offset) / 2 )
FROM sys.dm_exec_sql_text(sql_handle)
)
AS query_text
FROM sys.dm_exec_query_stats
ORDER BY [ avg_cpu_cost ] DESC

--以上DMV只显示当前被缓存的查询合计统计信息
--为了找出工作负荷中运行最频繁的查询,就需要执行下面的DMV查询。

 
 
SELECT TOP 10 total_worker_time ,plan_handle,execution_count,
(
SELECT SUBSTRING ( text ,statement_start_offset / 2 + 1 ,
(
CASE WHEN statement_end_offset =- 1
THEN LEN ( CONVERT ( NVARCHAR ( max ), text )) * 2
ELSE statement_end_offset
END - statement_start_offset) / 2 )
FROM sys.dm_exec_sql_text(sql_handle)
)
AS query_text
FROM sys.dm_exec_query_stats ORDER BY execution_count

--SQL Server在优化查询计划上花费的时间可以用下面的DMV查询

 
 
SELECT * FROM sys.dm_exec_query_optimizer_info WHERE counter = ' optimizations '
UNION
SELECT * FROM sys.dm_exec_query_optimizer_info WHERE counter = ' elapsed time '


SELECT TOP 10 plan_generation_num ,plan_handle,execution_count,
(
SELECT SUBSTRING ( text ,statement_start_offset / 2 + 1 ,
(
CASE WHEN statement_end_offset =- 1
THEN LEN ( CONVERT ( NVARCHAR ( max ), text )) * 2
ELSE statement_end_offset
END - statement_start_offset) / 2 )
FROM sys.dm_exec_sql_text(sql_handle)
)
AS query_text
FROM sys.dm_exec_query_stats
WHERE plan_generation_num > 1
ORDER BY execution_count


 
 --检查高速缓存内存

 
 
DBCC memorystatus


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/dz45693/archive/2010/01/27/5260697.aspx

目录
相关文章
|
SQL 运维 关系型数据库
一款 SQL 自动检查神器,再也不用担心 SQL 出错了,自动补全、回滚等功能大全
一款 SQL 自动检查神器,再也不用担心 SQL 出错了,自动补全、回滚等功能大全
393 0
|
SQL 监控 关系型数据库
MySQL数据库中如何检查一条SQL语句是否被回滚
检查MySQL中的SQL语句是否被回滚需要综合使用日志分析、事务状态监控和事务控制语句。理解和应用这些工具和命令,可以有效地管理和验证数据库事务的执行情况,确保数据的一致性和系统的稳定性。此外,熟悉事务的ACID属性和正确设置事务隔离级别对于预防数据问题和解决事务冲突同样重要。
424 2
|
缓存 Ubuntu Linux
在Linux中,如何检查系统的CPU和内存使用情况?
在Linux中,如何检查系统的CPU和内存使用情况?
|
SQL 缓存 关系型数据库
[mysql]状态检查常用SQL
[mysql]状态检查常用SQL
584 0
|
SQL Windows
安装SQL Server 2005时出现对性能监视器计数器注册表值执行系统配置检查失败的解决办法...
安装SQL Server 2005时出现对性能监视器计数器注册表值执行系统配置检查失败的解决办法...
260 4
|
SQL 索引 关系型数据库
MySQL设计规约问题之为什么推荐使用EXPLAIN来检查SQL查询
MySQL设计规约问题之为什么推荐使用EXPLAIN来检查SQL查询
|
SQL 关系型数据库 分布式数据库
在PolarDB中,如果慢SQL导致了CPU升高,进而又产生了更多的慢SQL
【2月更文挑战第22天】在PolarDB中,如果慢SQL导致了CPU升高,进而又产生了更多的慢SQL
205 1
|
SQL 关系型数据库 数据库
sql检查数据库
在SQL中,要检查数据库的存在、状态或相关信息,你通常需要使用特定于数据库管理系统的系统视图或命令。不同的数据库管理系统(如MySQL、SQL Server、PostgreSQL等)有不同的方法来执行
|
缓存 监控 前端开发
如何在 Linux 命令行中检查 CPU 使用率
【5月更文挑战第8天】
1635 0
|
监控 Ubuntu
百度搜索:蓝易云【如何使用各种工具和命令来检查Ubuntu中的CPU使用情况?】
这些工具和命令可以帮助你实时监控和检查Ubuntu系统中的CPU使用情况。你可以根据需要选择合适的工具来查看CPU使用情况,并根据情况采取相应的措施来优化系统性能。
360 1

热门文章

最新文章