SQL之收集SQL Server线程等待信息
要知道线程等待时间是制约SQL Server效率的重要原因,这一个随笔中将学习怎样收集SQL Server中的线程等待时间,类型等信息,这些信息是进行数据库优化的依据。
sys.dm_os_wait_stats
这是一个系统视图,里面存储线程所遇到的所有的等待信息,具体的列如下表
列名 |
数据类型 |
说明 |
Wait_type |
Nvarchar(60) |
等待类型名称 |
waiting_tasks_count |
Bigint |
等待类型的等待数。该计数器在每开始一个等待时便会增加。 |
Wait_time_ms |
Bigint |
该等待类型的总等待时间。 |
Max_wait_time_ms |
Bigint |
该等待类型的最长等待时间。 |
Signal_wait_time_ms |
Bigint |
正在等待的线程从收到信号通知到开始运行之间的时差。 |
要注意的是,这个视图的信息每次关闭SQL Server的时候都会自动清除,下次打开SQL Server的时候又会重新开始统计。
新建线程等待信息表
如果想得到连续的信息,在固定时间间隔内收集信息比如一个小时一次,这样就可以分析系统分配的等待时间,识别出繁忙时间段。这里我们将这些信息收集到一个数据表中保存并进行分析。使用下面的语句新建一个表:
- use AdventureWorks
- CREATE TABLE dbo.WaitStats
- (
- dt DATETIME NOT NULL DEFAULT (CURRENT_TIMESTAMP),
- wait_type NVARCHAR(60) NOT NULL,
- waiting_tasks_count BIGINT NOT NULL,
- wait_time_ms BIGINT NOT NULL,
- max_wait_time_ms BIGINT NOT NULL,
- signal_wait_time_ms BIGINT NOT NULL
- );
- CREATE UNIQUE CLUSTERED INDEX idx_dt_type ON dbo.WaitStats(dt, wait_type);
- CREATE INDEX idx_type_dt ON dbo.WaitStats(wait_type, dt);
新建job填充数据
要收集信息最好是用一个job来定时地执行insert语句填充数据,下面介绍步骤
点击数据库中的SQL Server Agent,展开,右击jobs文件夹,右击新建。如图1
在新建job界面,General标签中填写job名称,描述,如图2
点击Setps标签,点击新建按钮,在新建step界面内设置Step Name,Type,DataBase,Command等属性,如下图3。这些属性一看就知道是要做什么的,就不一一的解释了。还要说的 是截图是建好的job,如果你自己做的话对话框显示的标题可能不一样。
Command属性是设置要执行的SQL语句或存储过程等等,这里设置如下的SQL Script:
- INSERT INTO Performance.dbo.WaitStats
- (wait_type, waiting_tasks_count, wait_time_ms,
- max_wait_time_ms, signal_wait_time_ms)
- SELECT
- wait_type, waiting_tasks_count, wait_time_ms,
- max_wait_time_ms, signal_wait_time_ms
- FROM sys.dm_os_wait_stats
点击Shedules标签,设置job的执行计划,这里设置的是每天的每5分钟执行一次如图4
上述步骤包含了新建一个job的主要设置,其他的细节信息没有包含,遇到具体问题再具体分析吧。
收集等待信息数据
过一段时间之后在表WaitStats中就会有一些数据,每隔5分钟就会在这个表中写入一些数据,这些数据会不断的增加。这里为了得到相邻间隔之间线程等待时间的变化就要使用自连接,连接条件是等待类型相同,当前行号等于上一个的行号加上1,然后就可以用上一次等待时间减去这一次的等待时间得到这个变化值,下面使用一个函数来实现这个逻辑:
- IF OBJECT_ID('dbo.IntervalWaits', 'IF') IS NOT NULL
- DROP FUNCTION dbo.IntervalWaits;
- GO
- CREATE FUNCTION dbo.IntervalWaits
- (@fromdt AS DATETIME, @todt AS DATETIME)
- RETURNS TABLE
- AS
- RETURN
- WITH Waits AS
- (
- SELECT dt, wait_type, wait_time_ms,
- ROW_NUMBER() OVER(PARTITION BY wait_type
- ORDER BY dt) AS rn
- FROM dbo.WaitStats
- )
- SELECT Prv.wait_type, Prv.dt AS start_time,
- CAST((Cur.wait_time_ms - Prv.wait_time_ms)
- / 1000. AS NUMERIC(12, 2)) AS interval_wait_s
- FROM Waits AS Cur
- JOIN Waits AS Prv
- ON Cur.wait_type = Prv.wait_type
- AND Cur.rn = Prv.rn + 1
- AND Prv.dt >= @fromdt
- AND Prv.dt < DATE
- ADD(day, 1, @todt)
- GO
这个函数接受两个参数,开始统计时间,结束统计时间,返回等待变化的时间,并按照类型排序。调用这个函数如下:
SELECT wait_type, start_time, interval_wait_s
FROM dbo.IntervalWaits('20110509', '20110510') AS F
ORDER BY SUM(interval_wait_s) OVER(PARTITION BY wait_type) DESC,wait_type,start_time;
但是我们不能每次都去调用这个函数,所以可以吧这个查询放在一个视图里面,外部只需要使用视图来查询数据就可以了:
- IF OBJECT_ID('dbo.IntervalWaitsSample', 'V') IS NOT NULL
- DROP VIEW dbo.IntervalWaitsSample;
- GO
- CREATE VIEW dbo.IntervalWaitsSample
- AS
- SELECT wait_type, start_time, interval_wait_s
- FROM dbo.IntervalWaits('20090212', '20090215')
- AS F;
- GO
从视图中查询得到的数据就是我们要得到的数据。但是这些并不明显,先写到这里,下一个随笔我将在EXECL中把这些数据制作成一个直方图或者连线图,横轴是时间,纵轴是等待间隔时间。这样就会更加直观地看到在那些时间SQL Server的线程等待时间最长,也就是最繁忙的时候。
原文链接:http://www.cnblogs.com/tylerdonet/archive/2011/05/10/2042447.html
SQL之收集SQL Server线程等待信息的更多相关文章
- sql server线程等待信息
http://www.cnblogs.com/lyhabc/articles/3236984.html http://blog.csdn.net/isoleo/article/details/4547 ...
- SQL点滴13—收集SQLServer线程等待信息
原文:SQL点滴13-收集SQLServer线程等待信息 要知道线程等待时间是制约SQL Server效率的重要原因,这一个随笔中将学习怎样收集SQL Server中的线程等待时间,类型等信息,这些信 ...
- 收集SQLServer线程等待信息
要知道线程等待时间是制约SQL Server效率的重要原因,这一个随笔中将学习怎样收集SQL Server中的线程等待时间,类型等信息,这些信息是进行数据库优化的依据. sys.dm_os_wait_ ...
- SQLServer中使用扩展事件获取Session级别的等待信息以及SQLServer 2016中Session级别等待信息的增强
本文出处:http://www.cnblogs.com/wy123/p/6835939.html 什么是等待 简单说明一下什么是等待:当应用程序对SQL Server发起一个Session请求的时候, ...
- SQL Server里等待统计(Wait Statistics)介绍
在今天的文章里我想详细谈下SQL Server里的统计等待(Wait Statistics),还有她们如何帮助你立即为什么你的SQL Server当前很慢.一提到性能调优,对我来说统计等待是SQL S ...
- 如何有效抓取SQL Server的BLOCKING信息
原文:如何有效抓取SQL Server的BLOCKING信息 转自:微软亚太区数据库技术支持组 官方博客 http://blogs.msdn.com/b/apgcdsd/archive/2011/12 ...
- sql server 各种等待类型-转
等待的类型 资源等待 当某个工作线程请求访问某个不可用的资源(因为该资源正在由其他某个工作线程使用,或者该资源尚不可用)时,便会发生资源等待.资源等待的示例包括锁等待.闩锁等待.网络等待以及磁盘 I/ ...
- SQL Server删除表信息的三种方法
1.使用DELETE实现SQL Server删除表信息 (1)删除表中的全部信息 USE student GO DELETE student --不加where条件,删除表中的所有记录 go ...
- SQL SERVER常见等待——解决会话等待产生的系统问题
SQL SERVER——解决会话等待产生的系统问题 转自: https://blog.csdn.net/z_cloud_for_SQL/article/details/55051215 版权声明:SQ ...
随机推荐
- 【noip】noip201503求和(市赛后公布)
3. 求和 难度级别:B: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 题目描述 一条狭长的纸带被均匀划分出了n个格子,格子编号从1到n.每个格子 ...
- Fedora17安装MySQL及配置
一.安装 以下操作均是在root用户下进行操作.首先,如果以前有安装过,这次卸载后安装的话,最好是先将/var/lib/mysql/里面的内容全部删掉(如果不重要的话),我就遇到过没有删除这些东西,结 ...
- CGI和ISAPI
1) CGI概念CGI即通用网关接口(Common Gateway Interface),它是一段程序,运行在服务器上,提供同客户端HTML页面的交互,通俗的讲CGI就象是一座桥,把网页和WEB服务器 ...
- C语言中的栈和堆
原文出处<http://blog.csdn.net/xiayufeng520/article/details/45956305#t0> 栈内存由编译器分配和释放,堆内存由程序分配和释放. ...
- iOS 开发快速导引:TableView 和 CoreData【草】
所有列表式的数据都是用 TableView 显示的 预览 待补充 原料 NSFetchedResultsController 用来操作 NSFetchRequst,有执行查询,监听变化,数据缓存等功能 ...
- matlab 中 eps 的分析
eps(a)是|a|与大于|a|的最小的浮点数之间的距离,距离越小表示精度越高.默认a=1: 这里直接在matlab中输入:eps == eps(1)(true). 我们知道浮点数其实是离散的,有限的 ...
- CYQ.Data V5 MDataTable 专属篇介绍
前言 以前一两个月才出一篇,这三天有点变态地连续1天1篇(其实都是上周末两天写好的存货). 短期应该没有新的和此框架相关的文章要写了,这应该是最后一篇,大伙且看且珍惜. 前两篇讲数据库读写分离和分布式 ...
- Java NIO3:通道和文件通道
通道是什么 通道式(Channel)是java.nio的第二个主要创新.通道既不是一个扩展也不是一项增强,而是全新的.极好的Java I/O示例,提供与I/O服务的直接连接.Channel用于在字节缓 ...
- 《3D Math Primer for Graphics and Game Development》读书笔记1
<3D Math Primer for Graphics and Game Development>读书笔记1 本文是<3D Math Primer for Graphics and ...
- 在浏览器的背后(二) —— HTML语言的语法解析
当你看到这篇文章意味着我辜负了@教主的殷切期望周末木有去约会,以及苏老师@我思故我在北京鼓楼的落井下石成功了…… 本文demo powered by 已经结婚的@老赵的不再维护的wind.js 物是人 ...