11

我们有一个带有 SQL Server 2008 的 Windows 2008 R2 Server。该服务器有多个具有 SQL 服务器数据库的 .net 站点。

我们目前的平均 CPU 使用率为 95%,其中大部分使用由 SQL Server 负责。

我想确定哪个站点对此负责,以便我们可以对其进行优化或将其移至另一台服务器。但我没有找到任何直接的方式来看待这个。

我一直在寻找是否可以找到:

  • 获得最多 CPU 密集型查询的数据库
  • 负责 CPU 密集型查询的进程

使事情复杂化的一件事是我们有多个站点和使用同一个数据库的“crons”。因此,一旦我确定了数据库,我还需要获得一些关于哪个站点/cron 负责它的提示。

我真的很感谢任何帮助,因为这个问题使我们的网站真的很慢......

谢谢

4

2 回答 2

28

您可以使用 DMV 识别代价高昂的查询(以及与之关联的数据库),例如来自这篇 TechNet 文章

SELECT TOP 50
 [Average CPU used] = total_worker_time / qs.execution_count,
 [Total CPU used] = total_worker_time,
 [Execution count] = qs.execution_count,
 [Individual Query] = SUBSTRING (qt.text,qs.statement_start_offset/2, 
         (CASE WHEN qs.statement_end_offset = -1 
            THEN LEN(CONVERT(NVARCHAR(MAX), qt.text)) * 2 
          ELSE qs.statement_end_offset END - 
qs.statement_start_offset)/2)
,[Parent Query] = qt.text
,DatabaseName = DB_NAME(qt.dbid)
FROM sys.dm_exec_query_stats qs
CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) as qt
ORDER BY [Average CPU used] DESC;

这些将告诉您有关重击查询的信息,但不幸的是,它不会查明可能具有大量小型查询的数据库,这些查询单独使用少量 CPU,但总体使用大量 CPU。您可以通过 Glenn Allan Berry 的 DMV 查询中的查询来做到这一点:

WITH DB_CPU_Stats
AS
(SELECT DatabaseID, DB_Name(DatabaseID) AS [DatabaseName], 
  SUM(total_worker_time) AS [CPU_Time_Ms]
 FROM sys.dm_exec_query_stats AS qs
 CROSS APPLY (SELECT CONVERT(int, value) AS [DatabaseID] 
              FROM sys.dm_exec_plan_attributes(qs.plan_handle)
              WHERE attribute = N'dbid') AS F_DB
 GROUP BY DatabaseID)
SELECT ROW_NUMBER() OVER(ORDER BY [CPU_Time_Ms] DESC) AS [row_num],
       DatabaseName, [CPU_Time_Ms], 
       CAST([CPU_Time_Ms] * 1.0 / SUM([CPU_Time_Ms]) 
       OVER() * 100.0 AS DECIMAL(5, 2)) AS [CPUPercent]
FROM DB_CPU_Stats
WHERE DatabaseID > 4 -- system databases
AND DatabaseID <> 32767 -- ResourceDB
ORDER BY row_num OPTION (RECOMPILE);

这些查询都不能识别运行它们的应用程序,并且使用的 DMV 不存储该信息(您必须在行为中捕获查询并在 sys.dm_exec_sessions 中记下应用程序名称,或查看跟踪)。

当然,您可以使用市场上的各种 3rd 方性能工具来自动化这项工作(免责声明:我为其中之一工作,SQL Sentry,它生产Performance Advisor,它可以完成上述所有工作,包括跟踪高成本查询和维护有关它们在哪个数据库中运行以及哪个应用程序调用它们的信息)。

于 2012-04-25T16:47:07.190 回答
1

或者,您可以使用活动监视器查看服务器的运行状况。从那里你将能够挑选出长时间运行的查询,任何锁,如行锁、表锁等

http://www.mssqltips.com/sqlservertip/1917/performance-analysis-using-sql-server-2008-activity-monitor-tool/

于 2012-04-25T17:27:56.793 回答