上一篇,我们讲述了配置文件中与性能计数器相关的PerfmonCollector元素;这一篇我们将讲述与跟踪数据相关的ProfilerCollector元素。
在上一篇中使用SD_Detailed.XML配置文件在我本地收集5分钟跟踪数据文件为7Mb,当时没有做任何其他操作,试想如果在一个繁忙的生产环境,生成的跟踪文件大小将会更大。
跟踪数据,与添加的跟踪事件,系统繁忙程度有关。SQLdiag数据收集的大小不成比例地膨胀或捕获诊断数据时目标SQL Server性能降低的主要原因,是由于大量冗余或不相关的Profiler事件被添加到数据收集配置中。Profiler跟踪收集到目前为止是SQLdiag中最消耗资源的数据收集组件。
ProfilerCollector
本节将按照下面步骤测试:
1>禁用EventlogCollector、BlockingCollector、CustomDiagnostics元素收集器;PerfmonCollector、SqldiagCollector、ProfilerCollector元素保持启用
2>启用ProfilerCollector元素中的以下事件(类),其他事件全禁用

<EventType name="Database" enabled="true">
<Event name="Data File Auto Grow" enabled="true" id="92" />
<Event name="Log File Auto Grow" enabled="true" id="93" />
<EventType name="Stored Procedures">
<Event name="RPC:Completed" enabled="true" id="10" />
<EventType name="TSQL">
<Event name="SQL:BatchCompleted" enabled="true" id="12" />

事件类别添加方针可参考《SQL Server 2012 深入解析与性能优化(第3版)》11.5.2 过滤噪音,分析问题不能一劳永逸,要针对具体情况适当启用/禁用事件。
我们使用SQLDiagPerfStats_Detailed_Trace2008new.XML配置文件收集5分钟数据:

cd D:\Program Files\Microsoft SQL Server\\Tools\Binn\
SQLdiag /I F:\TroubleShooting\SQLdiag\input\SQLDiagPerfStats_Detailed_Trace2008new.XML /O F:\TroubleShooting\SQLdiag\LocalOutput /E +::

待它出现绿色字体"Collection started"后,参考RML Utilities for SQL Server分析一个.trc文件

ReadTrace -I"F:\TroubleShooting\Trace\HighDuration20151212.trc" -o"F:\TroubleShooting\Trace\output" -S"127.0.0.1,7777" -d"PerfAnalysis_CL" -E

由于已有的HighDuration20151212.trc文件比较小,RML很快就分析完成。在自动打开的Reporter中,我们随便点击查看。只是为了模拟应用程序使用数据库的情形,SQLdiag收集5分钟后会自动结束。
我们仔细回想一下,在配置文件的ProfilerCollector元素中,我们只能启用/禁用事件(类),不能操作事件列!默认应该会添加事件对应的所有可用事件列,而且不会编辑列筛选器!
我们可以打开收集结束的跟踪文件,查看跟踪文件属性。如前所料,大部分事件列都被勾选,没有列筛选,5分钟跟踪文件中的记录数有833行:

但是生产环境中,我们可能期望加上必要的筛选。我们可能只想监控某个程序、或者某个登录名、或者TextData含某个关键字、或者CPU/Duration/Reads满足某条件的语句。
为SQLdiag配置添加跟踪过滤器
通过情况下,Profiler跟踪过滤器被添加到SQL Server数据收集中以减少由SQLdiag收集的诊断数据的数据量。请注意,文本过滤器会给数据收集增加CPU的开销,因为评估基于文本的过滤器会有显著的CPU开销,而整数型的过滤器不会有。如果使用SQLdiag的XML配置文件收集Profiler跟踪,需要遵循以下步骤:
1>启动服务器中的SQLdiag
2>使用fn_trace_getinfo函数或sys.traces视图找到Profiler跟踪的跟踪ID
3>使用sp_trace_setstatus停止跟踪,而不必删除定义
4>使用从第2步获得的跟踪ID,并使用sp_trace_setfiler存储过程来设置过滤器
5>使用fn_trace_getfilterinfo函数验证过滤器是活跃的
6>当你对过滤器是活跃的感到满意时,使用sp_trace_setstatus开始跟踪数据收集
为了测试,我们重新开启SQLdiag,使用下面脚本添加跟踪CPU>10的语句:

-- 获取跟踪文件的跟踪ID
declare @TraceID int
select @TraceID=id from sys.traces where [path] LIKE '%sp_trace.trc' -- 停止功能
exec sp_trace_setstatus @TraceID, 0 -- Set the Filters
declare @intfilter int
declare @bigintfilter bigint --Get trace_column_id
--select * from sys.trace_columns tc --set @bigintfilter = 1000000
--exec sp_trace_setfilter @TraceID, 13, 0, 4, @bigintfilter--Duration>=1s --set @bigintfilter = NULL
--exec sp_trace_setfilter @TraceID, 13, 0, 1, @bigintfilter--排除不包含值的行 set @intfilter = 10
exec sp_trace_setfilter @TraceID, 18, 0, 4, @intfilter--CPU>10 set @intfilter = NULL
exec sp_trace_setfilter @TraceID, 18, 0, 1, @intfilter--排除不包含值的行 -- 启动功能
exec sp_trace_setstatus @TraceID, 1

我们同样分析一个.trc跟踪文件,并查看Reporter数据,5分钟后打开Profiler跟踪数据:

我们可以看到,跟踪文件中有Trace Stop/Start,在Stop之前有CPU=0的记录,Stop之后只有满足CPU>=10(ms)的才被跟踪到。同时注意5分钟跟踪文件中的记录数只有81行。实际操作中我们可以根据情况调整前面的过滤筛选值,其实我们可以将它保存到名为SQL_2008_SetFilters.sql的文件中,再将它添加到自定义收集器,那样就不用每次启动SQLdiag后再手动为跟踪数据添加过滤器。
SQL Nexus下的跟踪数据报表
我们使用SQL Nexus导入收集的SQLdiag数据,此时主界面的Perfmon Summary(性能计数器)、ReadTrace Reports(跟踪文件)都是可用的。点击ReadTrace Reports出现的页面是否很熟悉?对,它就是我们在RML中所看到的界面。
首先我们来看总界面Performance Overview:

然后点击Application Name,按Duration的总数排序:

我们可以直接点击Application Name,跳转到相关AppName下的Top Unique Batches,或者返回到Performance Overview页面,点击Unique Batches:

滚动鼠标滑轮,下面是Top Unique Batches按CPU排序的语句信息:

实际操作感觉SQL Nexus中的ReadTrace Reports没有单独使用RML全面,Parameters在SQL Nexus中貌似不起作用,不知是自己电脑有问题还是其他原因。
--10:53 2016/1/11
前天添加过滤器的跟踪在2016-01-09 13:42:20.250 Start,在2016-01-09 13:42:21.543 Stop,应用筛选后在2016-01-09 13:42:21.547重新Start,最后在2016-01-09 13:47:37.033 Stop


将跟踪用RML或SQL Nexus导入,开始时间-结束时间(1:42:20PM-1:42:22PM)只有两秒钟,只能导入sp_trace_setstatus停止跟踪前的数据

查看RML输出日志(日志保存于-o参数的路径下)、或者查看Nexus Log会提示ReadTrace参数(一般在C:\Users\Administrator\AppData\Local\Temp\RML\),说是Reached the end of the trace; found [TRACE_STOP_EVENT]

前面的Stop是为了添加过滤器,从跟踪结果看过滤器是应用上了,但是使用RML导入分析却被TRACE_STOP_EVENT"提前"结束,如何用RML分析Stop后的跟踪文件?

SQLdiag-配置文件-ProfilerCollector的更多相关文章

  1. SQLdiag-初识

    SQLdiag是一个命令行实用工具,默认情况下,在C:\Program Files\Microsoft SQL Server\100\Tools\Binn目录下可用.首先我们打开SQLdiag.exe ...

  2. SQLdiag Utility

    使用SQLdiag 会进行信息搜集类型 Windows 系统性能日志 Windows 系统日志 SQL Server 性能信息 SQL Server 阻塞信息 SQL Server 配置信息 如何使用 ...

  3. 使用SQLdiag Utility搜集SQL Server诊断信息

    SQLdiag Utility用于搜集诊断信息,给Microsoft技术支持人员做为判断依据. 使用SQLdiag 会进行信息搜集类型 Windows 系统性能日志 Windows 系统日志 SQL ...

  4. 【监控笔记】【1.4】Pssdiag和Sqldiag管理器

    --没有实操过,有点复杂,先写上以后有用到再深入研究 统计与诊断数据是任何 SQL故障修复工作的关键所在. 如果没有掌握这些数据,就无法确定数据性能问题的根源.数据表的瓶颈可能并不是由索引问题造成的: ...

  5. .Net Core MVC 网站开发(Ninesky) 2.3、项目架构调整(续)-使用配置文件动态注入

    上次实现了依赖注入,但是web项目必须要引用业务逻辑层和数据存储层的实现,项目解耦并不完全:另一方面,要同时注入业务逻辑层和数据访问层,注入的服务直接写在Startup中显得非常臃肿.理想的方式是,w ...

  6. ASP.NET MVC5+EF6+EasyUI 后台管理系统(64)-补充WebApi与Unity注入-配置文件

    系列目录 上一篇演示了WebApi利用Unity注入 很多人问我如何用配置文件来配置注入,本节演示如何利用配置文件来注入,道理是一样的,跳转到上一节下载源码一起来动手! 1.打开源码定位到文件Depe ...

  7. Spring配置文件标签报错:The prefix "XXX" for element "XXX:XXX" is not bound. .

    例如:The prefix "context" for element "context:annotation-config" is not bound. 这种 ...

  8. nginx服务器安装及配置文件详解

    nginx在工作中已经有好几个环境在使用了,每次都是重新去网上扒博客,各种编译配置,今天自己也整理一份安装文档和nginx.conf配置选项的说明,留作以后参考.像负载均衡配置(包括健康检查).缓存( ...

  9. C#开发中使用配置文件对象简化配置的本地保存

    C#开发中使用配置文件对象简化配置的本地保存 0x00 起因 程序的核心是数据和逻辑,开发过程中免不了要对操作的数据进行设置,而有些数据在程序执行过程中被用户或程序做出的修改是应该保存下来的,这样程序 ...

随机推荐

  1. 【iM_TFTRGB液晶模块】demo例程(版本1.02)发布

    ============================== 技术论坛:http://www.eeschool.org 博客地址:http://xiaomagee.cnblogs.com 官方网店:h ...

  2. Jquery&JS简单选项卡

    结果,如图 为了明显,用绿色+红色 第一步:静态布局 先写html代码和css样式 要点一:  ul li都为块级元素,可以用height,但是里面字体不居中,我们用line-height,即达到居中 ...

  3. Frenetic QuickInstall

    Frenetic a family of network programming languages 官方网站:Frenetic Github:Frenetic QuickInstall 第一步,先安 ...

  4. MySQL 日期和时间戳互相转换

    ① 时间戳转换成日期 FROM_UNIXTIME 例如: 数据表中 invest_time 存储的是时间戳,如 1429063399 使用 FROM_UNIXTIME 可以把时间戳转换为日期: sel ...

  5. php程序效率优化的一些策略小结

    php程序效率优化的一些策略小结   1.在可以用file_get_contents替代file.fopen.feof.fgets等系列方法的情况下,尽量用 file_get_contents,因为他 ...

  6. github 有名的问题【ERROR: Permission to .git denied to user】

    小乌龙 以前一直是单兵做战,所以github repo对于我而言,只是一个存放.同步.备份代码的地方,协同作用完全没有体现出来. 最近跟朋友一起开发一个项目,他在github建了个公共的repo,我正 ...

  7. XPath学习:parent,child

    XPath 是一门在 XML 文档中查找信息的语言.XPath 可用来在 XML 文档中对元素和属性进行遍历. XPath 是 W3C XSLT 标准的主要元素,并且 XQuery 和 XPointe ...

  8. Delphi 如何清除动态数组的内存?

    SetLength(glb_IndexConfig,); FreeAndNil(glb_IndexConfig);

  9. Android 网络连接判断与处理

    Android网络连接判断与处理  获取网络信息需要在AndroidManifest.xml文件中加入相应的权限. <uses-permission android:name="and ...

  10. java ReentrantReadWriteLock

    // read and write lock is mutual exclusion lock //Listing 7-3. Using ReadWriteLock to Satisfy a Dict ...