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。
时间: 2024-10-13 16:01:17