百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> sql server机能调优 I/O开销的深入解析
分享文章到:

sql server机能调优 I/O开销的深入解析

发布时间:05/13 来源:未知 浏览: 关键词:

一.概述

IO 内存是sql server最重要的资源,数据从磁盘加载到内存,再从内存中缓存,输出到利用端,在sql server 内存初探中有介绍。在明确了sqlserver内存道理后,就能更好的剖析I/O开销,从而晋升数据库的整体机能。 在生产环境下数据库的sqlserver服务启动后一个星期,就可以通过dmv来剖析优化。在I/O剖析这块可以从物理I/O和内存I/O二方面来剖析, 重点剖析应在内存I/O上,可能从多个维度来剖析,比方从sql server服务启动以来 历史I/O开销总量剖析,自施行规划编译以来施行次数总量剖析,均匀I/0次数剖析等。

sys.dm_exec_query_stats:返回缓存的查询规划,缓存规划中的每个查询语句在该视图中对应一行。当sql server工作负载过重时,该dmv也有可以统计不准确。要是sql server服务重启缓存的数据将会清掉。这个dmv包括了太多的信息像内存扫描数,内存空间数,cpu耗时等,具体查看msdn文档。

sys.dm_exec_sql_text:返回的 SQL 文本批处置,它是由指定sql_handle,其中的text列是查询的文本。

1.1 按照物理读的页面数排序 前50名

SELECT TOP 50
 qs.total_physical_reads,qs.execution_count,
 qs.total_physical_reads/qs.execution_count AS [avg I/O],
 qs. creation_time,
 qs.max_elapsed_time,
 qs.min_elapsed_time,
 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) AS query_text,
 qt.dbid,dbname=DB_NAME(qt.dbid),
 qt.objectid,
 qs.sql_handle,
 qs.plan_handle
 from sys.dm_exec_query_stats qs
 CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS qt
 ORDER BY qs.total_physical_reads DESC

如下图所示:

  total_physical_reads:规划自编译后在施行期间所施行的物理读取总次数。

  execution_count :规划自上次编译以来所施行的次数。

  [avg I/O]:    均匀读取的物理次数(页数)。

  creation_time:编译规划的工夫。

        query_text:施行规划对应的sql脚本

       背面来包括所在的数据库ID:dbid,数据库名称:dbname

1.2 按照逻辑读的页面数排序 前50名

SELECT TOP 50
 qs.total_logical_reads,
 qs.execution_count,
 qs.max_elapsed_time,
 qs.min_elapsed_time,
 qs.total_logical_reads/qs.execution_count AS [AVG IO],
 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) 
 AS query_text,
 qt.dbid,
 dbname=DB_NAME(qt.dbid),
 qt.objectid,
 qs.sql_handle,
 creation_time,
 qs.plan_handle
 from sys.dm_exec_query_stats qs
 CROSS APPLY sys.dm_exec_sql_text(qs.sql_handle) AS qt
 ORDER BY qs.total_logical_reads DESC

如下图所示:

通过上面的逻辑内存截图来简要剖析下:

  从内存扫描总量上看最多的是8311268次页扫描,自施行编译后运转t-sql脚本358次,这里的耗时是毫秒为单位包括最大耗时和最小耗时,均匀I/O是232115次(页),该语句文本是一个update 修改,该表数据量大没有完全走索引(权衡后不对该语句做索引遮盖),但施行次数少,且每次施行工夫是非工作工夫,虽然扫描开销大,但没有影响白天客户运用。

  从施行次数是有一个43188次, 内存扫描总量排名39位。该语句虽然只要815条,但施行次数许多,如里服务器有压力可以优化,个别是该语句没有走索引。把文本拿出来如下

SELECT Count(*) AS TotalCount FROM [MEM_FlagshipApply]
 WITH(NOLOCK) Where (((([Status] = 2) AND ([IsDeleted] = 1)) AND ([MemType] = 0)) AND ([MEMID] <> 6))

下面两图一个是剖析该语句的施行规划,sqlserver提醒短少索引,另一个是i/o统计扫描了80次。

新建索引后在来看看

 CREATE NONCLUSTERED INDEX ix_1
ON [dbo].[MEM_FlagshipApply] ([Status],[IsDeleted],[MemType],[MEMID])

  

     

总结

以上就是这篇文章的全部内容了,但愿本文的内容对大家的学习或者工作拥有一定的参考学习价值,要是有疑难大家可以留言交换,感谢大家对我们的支撑。

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有154人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板