欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

自动化收集SQLSERVER诊断信息的工具选择及使用介绍

程序员文章站 2023-12-11 08:25:22
自动化收集sqlserver诊断信息 相信很多人都遇到过当sqlserver出现问题的时候,而你又解决不了需要dba或者微软售后支持工程师去帮忙解决问题,那么他们一般需要...

自动化收集sqlserver诊断信息

相信很多人都遇到过当sqlserver出现问题的时候,而你又解决不了需要dba或者微软售后支持工程师去帮忙解决问题,那么他们一般需要你收集一些系统信息和sqlserver诊断信息。

而收集这些信息又需要图形工具,又需要指令,步骤又非常复杂。

我们要按照步骤一步一步把需要的信息收集全,在收集的过程中,往往折腾几次就头痛了


解决问题的工具

这个问题随着一个在sql2005里的工具的出现而得到了解决

这个工具可以自动收集很多信息,扩展了原来的应用,增强了其信息收集的能力

这个工具就是sqldiag.exe    sql代表:sqlserver  diag 代表diagnostic(诊断)

sqldiag这个工具可以收集的信息有:

(1)windows事件日志

(2)sqlserver errorlog,以及sql配置信息,一些重要运行信息

(3)sql曾经产生的dump文件

(4)服务器系统配置信息

(5)同时包含有系统和sql性能计数器的性能日志

(6)服务器端trace

这个工具可以帮助dba自动打开服务器端trace,比用sqlserver profiler要安全多了

因为sqlserver profiler属于客户端跟踪工具,而且需要消耗系统资源跟服务器通信需要

进程间通信,而这个工具用的是服务器端trace

sqldiag工具默认安装在:c:\program files\microsoft sql server\90\tools\binn

c盘是我的sqlserver安装路径,大家安装sqlserver不是选择默认路径的话可能跟我不一样


使用工具

 这个工具需要在命令行窗口运行,可以在命令行直接运行\sqldiag.exe,工具会使用默认的配置,收集系统信息

 把sqldiag.exe拖到cmd窗口,按回车键就可以启动了,详细步骤看下图

自动化收集SQLSERVER诊断信息的工具选择及使用介绍

 当出现sqldiag collection started.  press ctrl+c to stop. 信息以后就按crtl+c,终止这个工具的执行。

sqldiag 工具会在binn目录下产生三个xml文件,并且产生一个sqldiag子目录,存放刚才收集的信息

 自动化收集SQLSERVER诊断信息的工具选择及使用介绍

自动化收集SQLSERVER诊断信息的工具选择及使用介绍

 使用默认配置(即binn目录下的sqldiag.xml)只会收到:

(1)sql errorlog文件内容,以及sql配置信息和一些重要运行信息(xxxx_sp_sqldiag_shutdown.out)

(2)sql曾经产生的dump记录(xxxx_sqldumper_errorlog.log)

(3)服务器系统配置信息(xxxx_msinfo32.txt)

(4)sql默认开启的default trace文件(log_xxx.trc)


使用配置文件

 你可以使用另外两个sqldiag自带的xml配置文件sd_general.xml 和 sd_detailed.xml,这两个xml文件跟sqldiag.exe在同一目录下,

如果使用这两个配置文件就能够收集到sql trace和性能日志。

但是如果要使用这两个配置文件所产生的文件就会比较大,放在sql安装目录下就不再合适,

需要在sqldiag里指定输出文件路径。

例子 在cmd下输入:

格式:sqldiag.exe /i <configure_file> /o <output_directory>

我使用sd_general.xml配置文件,配置f:\sqldiaout为输出目录,这个文件夹不用预先创建好,他最帮你自动创建

sqldiag.exe /i sd_general.xml /o f:\sqldiaout

 自动化收集SQLSERVER诊断信息的工具选择及使用介绍

运行的过程中能够看到sqldiag开启perfmon(addingperfmon counters)和trace(starting profiler trace)

当问题跟踪完毕以后,再按ctrl+c工具会停止日志收集。

有些信息是在工具关闭前收集的,所以可能要等一会才能完全停止

 而在目录下 f:\sqldiaout目录,可以看到以下信息

(1)sql trace文件(xxxx_sp_trace.trc)

(2)windows事件日志(xxxx_applog_shutdown.txt,xxxx_seclog_shutdown.txt,xxxx_syslog_shutdown.txt)

(3)windows性能日志(sqldiag.blg) 用性能监视器也打不开这个文件,要使用系统自带的小工具


总结

实际上,两个xml配置文件sd_general.xml 和 sd_detailed.xml的主要区别是sd_detailed.xml会在sql trace里收集更多的事件,

所以输出会要大很多。

dba可以根据需要选择其中一个

缺点:

sqldiag的唯一缺点,是不会定期查询系统管理视图dmv,

所以建议自动化信息收集是sqldiag(使用sd_general.xml 和 sd_detailed.xml做配置文件),在加上一些

系统动态管理视图作为辅助