0. 跟踪标记 (Trace Flag) 简介

. 什么是跟踪标记sql

SQL Server 跟踪标记(Trace Flag),像是一个开关,可用来自定义SQL Server的某种行为或特性,在性能诊断,系统调试等方面较为经常使用。好比:开启1204或1222跟踪标记,可在errorlog里记录死锁信息的明细。数据库

跟踪标记有会话级和实例级两种。性能

 

. 如何开启跟踪标记测试

1. SQL Server 服务启动时开启spa

SQL Server服务从相似以下路径启动程序:命令行

C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQL2016\MSSQL\Binn\sqlservr.exe调试

而sqlservr.exe接受一些启动参数,其中就包含了跟踪标记。code

 

以命名实例MSSQL2016,跟踪标记610 为例: blog

1.1 使用sqlservr.exe来启动文档

(1) 先停掉服务 (以管理员身份运行cmd命令窗口)

默认实例:net stop MSSQLSERVER / net stop "SQL Server (MSSQLSERVER)"

命名实例:net stop MSSQL$MSSQL2016 / net stop "SQL Server (MSSQL2016)"

 

(2) 启动服务 (先cd切换到sqlservr.exe目录)

默认实例:sqlservr.exe –T610

命名实例:sqlservr.exe -sMSSQL2016 –T610

 

命令行举例:

C:\Windows\system32>net stop MSSQL$MSSQL2016
The SQL Server (MSSQL2016) service is stopping.
The SQL Server (MSSQL2016) service was stopped successfully.

C:\Windows\system32>cd C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQL2016\MSSQL\Binn\
C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQL2016\MSSQL\Binn>sqlservr -sMSSQL2016 -T610

 

在数据库里执行SQL语句,可看到已启动的跟踪标记:

dbcc tracestatus(-1)
--TraceFlag    Status    Global    Session
--610    1    1    0

 

注:

(1) 以这种方式启动的SQL Server,服务状态仍然是中止,可是SSMS/SQLCMD都可以链接并执行SQL语句,一般用于系统故障诊断/维护时,不做为常规启动方式使用;

(2) 关闭当前的cmd窗口,便可关闭该次启动;

 

1.2使用net命令来启动

(1) 先停掉服务 (以管理员身份运行cmd命令窗口)

默认实例:net stop MSSQLSERVER 或 net stop "SQL Server (MSSQLSERVER)"

命名实例:net stop MSSQL$MSSQL2016或 net stop "SQL Server (MSSQL2016)"

 

(2) 启动服务(以管理员身份运行cmd命令窗口)

默认实例:net start MSSQLSERVER /T610 或net start "SQL Server (MSSQLSERVER)" /T610

命名实例:net start MSSQL$MSSQL2016 /T610 或net start "SQL Server (MSSQL2016)" /T610

 

命令行举例:

C:\Windows\system32>net stop MSSQL$MSSQL2016
The SQL Server (MSSQL2016) service is stopping.
The SQL Server (MSSQL2016) service was stopped successfully.

C:\Windows\system32>net start MSSQL$MSSQL2016 /T610
The SQL Server (MSSQL2016) service is starting.
The SQL Server (MSSQL2016) service was started successfully.

 

在数据库里执行SQL语句,可看到已启动的跟踪标记:

dbcc tracestatus(-1)
--TraceFlag    Status    Global    Session
--610    1    1    0

 

注:

(1) 以net命令启动SQL Server服务时,exe程序的参数经过斜线(/)来传递而不是横线(-):/T610;

 

1.3 使用配置管理器 (Configuration Manager) 来启动

打开SQL Server 配置管理器\SQL Server 服务\选择相应实例:

(1) 中止相应实例的服务

(2) 属性\启动参数, 输入-T610 并添加

(3) 启动相应实例的服务

 

在数据库里执行SQL语句,可看到已启动的跟踪标记:

dbcc tracestatus(-1)
--TraceFlag    Status    Global    Session
--610    1    1    0

 

注:

(1) 启动参数被保存在注册表里,在服务启动时加载,因此会一直有效,直到在启动参数中删除该项并保存;

(2) 在配置管理器中修改SQL Server服务相关的参数为最佳实践(Best Practice),推荐;

 

2. SQL Server 服务启动后开启

在SQL Server服务启动后,可经过DBCC命令来开/关跟踪标记

--开启会话级跟踪标记
dbcc traceon(610)
--会话级跟踪标记,只能在所在会话关闭
dbcc traceoff(610)

--开启实例级跟踪标记
dbcc traceon(610,-1)
--实例级跟踪标记,在全部会话均可关闭
dbcc traceoff(610,-1)

--指定-1,显示全部已开启跟踪标记
dbcc tracestatus(-1)

 

注:

(1) 会话级跟踪标记,只对当前会话有效,其余会话不受影响;

(2) 实例级跟踪标记,整个实例有效;

 

小结:

(1)    以上几种方式,只有在SQL Server配置管理器里修改启动参数添加跟踪标记,会被保存到注册表,从而每次启动服务时跟踪标记均可以生效,其余几种方式只是在当前的命令行里开启了跟踪标记选项,正常重启服务后,跟踪标记就不见了;

(2)    只有DBCC traceon 可开启会话级跟踪标记,其余开启方式均为实例级;

(3)    若是要在生产环境使用,请尽量多的测试,尤为是非文档记载的跟踪标记;

相关文章
相关标签/搜索