如果遇到间歇性故障,为了充分利用黑盒跟踪,就要确保当服务器运行时它也一直出于运行状态(包括计划中的或计划外重启之后)。为达到这个要求,可以将黑盒跟踪设置为在SQL Server启动时自动启动。首先,将跟踪定义封装在主数据库的一个存储过程中:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
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服务启动时自动启动:
1
2
|
EXEC
sp_procoption
'StartBlackBoxTrace'
,
'STARTUP'
,
'ON'
|
如果发生了崩溃事件,可以分析收集到的数据以确定崩溃当时有哪些存储过程或查询正在运行,并(很有希望)可以查出哪些出了问题。
停止并关闭跟踪ID为1的跟踪,可以执行以下脚本:
1
2
|
EXEC
sp_trace_setstatus 1, 0
EXEC
sp_trace_setstatus 1, 2
|
设置状态为0是停止跟踪,重新设置状态为1就是重启跟踪。你可以设置状态为2去关闭跟踪,但你必须已经停止了它。你不能重启一个关闭的跟踪,你必须完全重新创建。当你关闭了跟踪的时候,这个blackbox.trc文件可用。接着运行sqldiag拷贝完整的blackbox.trc文件到\log目录重命名为sqldiag.trc。
本文转自UltraSQL51CTO博客,原文链接:http://blog.51cto.com/ultrasql/1583065 ,如需转载请自行联系原作者