设为首页 收藏本站
查看: 1144|回复: 0

[经验分享] SQL Server Profiler -- 性能调校

[复制链接]

尚未签到

发表于 2018-10-12 07:09:45 | 显示全部楼层 |阅读模式
SQL Server Profiler -- 性能调校
  性能有足够的理由成为一个热点话题。当今商业领域竞争激烈,如果用户认为某个应用程序速度太慢,就会立刻转向另一个供应商。为了满足用户的要求,SQL跟踪加载了一些事件类,可以利用这些事件类来查找和调试性能瓶颈。
  性能监视技术可以大致分为两个类别:在已知故障相关知识时使用的技术和用来查找故障所在(或者查找到底是否存在故障)的技术。如果查出这个故障的某些问题,就可以在这方面获取更多的信息。因此,从第2种帮助精确定位故障区域的技术开始,然后再讨论怎样进行更详细的分析。
  当开始一个新的数据库性能调校工程时,首先要查明的就是哪个查询的效率最低。换言之,要确定最差性能的原因,这样可以找到最佳的调校效果。在这个阶段,不要跟踪太多的信息,通常只启动“Stored Procedures: RPC:Completed”和“TSQL: SQL:BatchCompleted”这两个事件。这些事件都在SQL Server性能分析器提供的TSQL_Duration模板中被选中。建议往这两个事件中添加默认模板中并没有选中的读、写和CPU列,以便获得更加完整的描述。也建议为“Stored Procedures: RPC:Completed”事件选择TextData列而不是(默认的)BinaryData列—这可以使后续处理数据的工作更简单。下图显示了一个完整的给定事件集合。
DSC0000.jpg

  如果选择了事件,就要在生存期列上设置一个以毫秒计的短时过滤器。使用过的大部分活动OLTP系统都有极其大量的0毫秒查询,且在性能瓶颈方面,这些显然不是最好的。通常从设置为100毫秒的过滤器开始,然后从开始进行工作。方法是增加每次迭代上的信噪比,淘汰较小的查询,只保留有较高潜力进行性能调校的查询。根据应用程序和服务器荷载的不同,通常对每个迭代跟踪运行10~15分钟,然后查看结果并适度地增加这个数值直到在跟踪期间只得到几百个事件为止。这个10~15分钟的数字对于有些特别忙的应用程序来说太长了。
  另一个选项是只运行初始跟踪,然后开始过滤结果。简单的方法就是使用SQL Server 2005的NTILE开窗函数,它将输入行分为数目相等的“桶”。如果只查看一个基于生存期的跟踪表里前10%的查询,可以使用如下查询:
SELECT *  
FROM
  
(
  
SELECT
  
*,
  
NTILE(10) OVER(ORDER BY Duration) Bucket
  
FROM TraceTable
  
) x
  
WHERE Bucket = 10
  注意:大量看上去很小的(甚至0毫秒的)查询组成的应用程序的执行也可能导致性能故障,但是这个问题一般需要通过移除无用的界面,系统有体系地解决,而不是通过Transact-SQL查询调校。如果不知道一个特定的应用程序的操作,那么通过性能分析查找这类问题也很困难,因此,这里不讨论这个问题。
  如果发现很难将获得的返回事件数量限制在一个可控制级别(在忙碌的系统上这是很常见的问题),就不得不对结果做一些调整以使输出聚合得更好一些。从SQL跟踪获得的结果包含了每个查询的未加工文本数据,这些数据包括所有被实际用到的参数。为了进一步分析结果,这些数据应该被载入数据库中的一张表里,然后进行聚合,例如,得出逻辑读的平均生存期或数目。
  问题在于如果成功地聚合SQL跟踪结果所返回的未加工文本数据。知道实际的参数有好处,对于重新产生性能问题很有用,但是在试图判断应当首先处理哪个查询前,最好先用查询“表单”聚合这些结果。例如,下列两个查询都是属于同一个表单,使用同样的表和列,只在WHERE子句使用的参数上有差别,但是由于它们的文本不同,因此要聚合它们是不可能的:
SELECT *  
FROM SomeTable
  
WHERE SomeColumn = 1
  
---
  
SELECT *
  
FROM SomeTable
  
WHERE SomeColumn = 2
  为了帮助解决这个问题,并将这些查询减少到可以聚合的一个常见表单,提供了一个CLR UDF,稍作修订的版本(也可以处理NULL)如下:
[Microsoft.SqlServer.Server.SqlFunction(IsDeterministic=true)]  
Public static SqlString sqlsig(SqlString querystring)
  
{
  
Return (SqlString)Regex.Replace(
  
Querystring.Value,
  
@”([\s,(=!](?![^\]]+[\]](?:(?:(?:(?:(?# expression coming
  
)(?:([N])?(‘)(?:[^’]’’)*(‘))(?# character
  
)|(?:0x[\da-fA-F]*)(?# binary
  
)|(?:[-+]?(?:(?:[\d]*\.[\d]*|[\d]+)(?# precise number
  
)(?:[eE]?[\d]*)))(?# imprecise number
  
)|(?:[~]?[-+]?(?:[\d]+))(?# interger
  
)|(?:[nN][uU][lL][lL])(?# null
  
))(?:[\s]?[\+\-\*\/\%\&|\^][\s]?)?)+(?# operatoers
  
)))#,
  
@”$1$2$3#$4”);
  
}
  该UDF查找出大部分像参数的值,用“#”替代。用UDF处理完上面的两个查询后,输出应该一样:
SELET *  
FROM SomeTable
  
WHERE SomeColumn = #
  要用该UDF帮助处理一个跟踪表以找出前几位查询,可以从接下来的查询的某些行开始,该查询聚合了每一个常用的查询表单,并得到了生存期、读、写和CPU的平均值:
SELECT  
QueryForm,
  
AVG(Duration),
  
AVG(Reads),
  
AVG(Writes),
  
AVG(CPU)
  
FROM
  
(
  
SELECT
  
Dbo.fn_sqlsig(TextData) AS QueryForm,
  
l.* Duration AS Duration,
  
l.* Reads AS Reads,
  
l.* Writes AS Writes,
  
l.* CPU AS CPU
  
FROM TraceTable
  
WHERE TextData IS NOT NULL
  
) x
  
GROUP BY QueryForm
  在这里,可以进一步用平均值进行过滤,以找出更多查询。
  如果决定了对一个或多个查询进行调校,就可以用SQL跟踪来帮助做进一步的分析。例如,假设已经将下列可以在AdventureWorks数据库中创建的存储过程作为故障原因隔离起来的显示:
CREATE PROCEDURE GetManagersAndEmployees  
@EmployeeID INT
  
AS
  
BEGIN
  
SET NOCOUNT ON
  
EXEC uspGetEmployeeManagers @EmployeeID
  
EXEC uspGetManagerEmployees @EmployeeID
  
END
  要开始一个会话以分析该存储过程在做什么,首先要在SQL Server管理工作室中打开一个新的查询窗口,用@@SPID函数获取会话的spid。接下来,打开SQL Server性能分析器,连接到服务器上,并选择调校模板。
DSC0001.jpg

  该模板将SP:StmtCompleted添加至用来获取服务器活动更完整描述的事件组合。这将导致每个调用都返回更多的数据,因此要用之前锁收集到的spid来过滤跟踪。用户也可能希望添加显示计划XML统计值性能分析事件,以撤销连同查询剩余信息在内的查询计划。下图显示了此类工作一个完整的事件选择屏幕。
  注意:添加一个显示计划XML或死锁图事件会使得跟踪性能对话框中新增一个名为事件提取设置的标签页,这个标签页包括自动保存任何已收集到的查询计划或死锁图XML至文本文件的选项,并可以防止以后需要时重新用到它们。
DSC0002.jpg

  接下来,继续启动SQL Server性能分析器里的跟踪。尽管通常使用服务器端跟踪做绝大部分的性能监视,但是用单个spid处理单个查询时性能分析器带给表的开销是很小,因此可以为此类工作充分利用UI。下图显示的是启动跟踪和运行@EmployeeID=21查询之后性能分析器的连续输出。选择显示计划XML事件中的一个,以突出该特性的能力。连通最外层存储过程执行的每个语句和调用的所有存储过程一起,用户可以看到在性能分析器UI中有一个完整的图形查询计划。这可使其称为帮助用户调校复杂多层存储过程的一个理想助手。
DSC0003.jpg

DSC0004.jpg

  SQL跟踪不会进行实际的调校,但是它能帮助查找可能导致故障的查询,以及这些查询中需要工作的组件。然而,它的功能远不止于性能调校而已。
  注意:SQL跟踪并不进行实际调校,SQL Server的数据库引擎优化顾问(DTA)工具可以跟踪一个输入文件,这样就可以在索引、统计值和分区方面帮助用户查询进行得更快。如果使用DTA工具,要确保提供系统通常所处理查询的足够多的样本。如果收集到的样本数目太多,结果就会有偏差,很可能就会导致DTA给出低水平的建议,甚至有可能提供导致其他尚未在输入集合的查询中产生性能故障的建议。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-620501-1-1.html 上篇帖子: SQL Server 镜像 下篇帖子: SQL Server 2005数据备份与还原
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表