SQL Server 黑盒跟踪 -- 如何在生产环境配置?

SQL Server 黑盒跟踪 -- 如何在生产环境配置?

如果遇到间歇性故障,为了充分利用黑盒跟踪,就要确保当服务器运行时它也一直出于运行状态(包括计划中的或计划外重启之后)。为达到这个要求,可以将黑盒跟踪设置为在SQL Server启动时自动启动。首先,将跟踪定义封装在主数据库的一个存储过程中:

 

USE master
GO
CREATE PROCEDURE StartBlackBoxTrace
AS
BEGIN
DECLARE @TraceId int
DECLARE @maxfilesize bigint
SET @maxfilesize = 25
EXEC sp_trace_create
@TraceId OUTPUT,
@options = 8,
@tracefile = NULL,
@maxfilesize = @maxfilesize
EXEC sp_trace_setstatus @TraceId, 1
END
GO

 

然后,将这个过程设置为SQL Server服务启动时自动启动:

EXEC sp_procoption
‘StartBlackBoxTrace‘, ‘STARTUP‘, ‘ON‘

 

如果发生了崩溃事件,可以分析收集到的数据以确定崩溃当时有哪些存储过程或查询正在运行,并(很有希望)可以查出哪些出了问题。

 

停止并关闭跟踪ID为1的跟踪,可以执行以下脚本:

EXEC sp_trace_setstatus 1, 0    
EXEC sp_trace_setstatus 1, 2

 

设置状态为0是停止跟踪,重新设置状态为1就是重启跟踪。你可以设置状态为2去关闭跟踪,但你必须已经停止了它。你不能重启一个关闭的跟踪,你必须完全重新创建。当你关闭了跟踪的时候,这个blackbox.trc文件可用。接着运行sqldiag拷贝完整的blackbox.trc文件到\log目录重命名为sqldiag.trc。

本文出自 “滴水石穿” 博客,请务必保留此出处http://ultrasql.blog.51cto.com/9591438/1583065

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。