你的位置:首页 > 数据库

[数据库]使用WinDbg调试SQL Server——入门


这篇文章我想探究下SQL Server里完全不同的领域:如果使用WinDbg(来自针对Windows的调试工具)调试SQL Server。在我们进入枯涩细节之前,我想详细解释下为什么选择这样晦涩的话题来写这篇文章。

缘由

当使用SQL Server时,你到底需不需要像WinDbg这样的调试器?简单回答:从不需要!SQL Server是一个稳定的产品,使用它提供的技术(扩展事件,DMVs/DMFs)进行故障排除已经可以了,从不会用到WinDbg。如果你有疑问的话,在你独自尝试调试讨厌的SQL Server问题前,你应该首先联系PSS。那使用像WinDbg的调试器的原因是什么?对我来说主要是教学,学习在SQL Server内部是如何工作的,还有关系数据库引擎是如何实现的。当我处理SQL Server问题时,有时候会看到在SQL Server里疯狂的事情,这是我要去解释的。因此我对SQL Server知道得更多,还有SQL Server如何工作的,对我来说是越好。

我使用WinDbg只出于教育目的,只在非生产的测试系统,为了更好的理解当执行查询时,SQL Server内部发生了什么。为此我们还要了解更多Windows系统的概念,用户模式调试,64位汇编语言,还有64位机器架构等。另外也要翻阅大量白皮书介绍关系数据库引擎是如何实现的。使用WinDbg我可以从内部看SQL Server,用哪个方式SQL Server实现它的功能,还有这些是如何一起工作的。最重要的是:像极客(geeky)一样去使用WinDbg调试器,大家都乐此不彼。

正题

在我们进入如何详细配置WinDbg对SQL Serve调试前,首先我想给你讲下SQL Server里最重要的DLL文件,在调试时我们会用到。我们来看下面图片:

 

我们知道,SQL Server本身是在可执行的sqlservr.exe里实现。在启动期间,sqlservr.exe会加载多个DLL文件到它的进程空间。从调试角度来说——下列是重要的几个DLL文件:

  • sqldk.dll (SQL Server开发包)目前实现SQL OS的大部分功能——这个OS是SQL Server的一部分,用来处理线程调度和内存管理(thread scheduling and memory mangement)。
  • sqlmin.dll实现所有关系引擎本身相关的功能,包括存储引擎(Storage Engine),数据访问方法(Data Access Methods),锁管理器(Lock Manager),日志管理器(Log Manager),惰性写入器(LazyWriter),还有其他组件。对于调试来说,它是最重要的一个,因为它包含SQL Server大多数熟知的组件。
  • sqllang.dll包含所有与T-SQL语言相关的功能,还有查询处理器(Query Processor)本身。

为了使用WinDbg,你需要先安装这个调试工具,它可以从微软免费下载:用于 Windows 的独立调试工具 (WinDbg)。

https://msdn.microsoft.com/zh-cn/windows/hardware/gg463028#Download_windows

(貌似微软网站都很难下载,现提供单独下载地址:

x86位版本下载:【微软官方安装版】

x64位版本下载:【微软官方安装版】

安装完成后,在开始菜单里就可以找到这个程序:

 

警告:附加debugger到sqlserver进程会停止SQLSERVER的运行,切记不要在生产环境上乱试!!!

当你启动WinDbg时,请确认你的账户有管理员权限,不然的话你是不能附加到像sqlservr.exe这样的进程。为了使用WinDbg,你需要配置符号表(symbols)。符号表文件是用来解码内存地址,对应函数名称,这样更容易我们调试和理解。当你使用符号表是,你要区分公共和私有符号表。除了微软能访问公共符号,我们只能访问私有符号。公共符号是私有符号的子集,不包括更有趣的东西,例如:

  • 数据类型定义
  • 本地变量定义
  • 函数参数

公共符号仅提供你函数名称——没别的信息!与私有符号相比,我们需要习惯它的巨大限制。但是另一方面,微软想要保护它们的知识产权。不过只拿到用于调用堆栈(call-stacks)完整函数名称,在它们上面设置断点,通过它们调试,就可以大大帮助你理解SQL Server内部是如何工作的。只要你正确配置了WinDbg,对于你调试的指定内建SQL Server,你拿到自动正确的公共符号。你也可以尝试本地内核模式调试(local Kernel Mode Debugging),你甚至可以拿到内核模式的正确符号——但这是另外一回事……在WinDbg里你要配置微软公共符号的服务器地址,这样的WinDbg就可以正常下载它们。地址是:

http://msdl.microsoft.com/download/symbols 

我是用批处理命令运行WinDbg,设置正确的符号服务器地址,直接附加到sqlservr.exe进程。 

首先我们在命令提示符里切换到WinDbg所在目录:

CD C:\Program Files\Debugging Tools for Windows (x86)

然后使用如下命令:

windbg -y srv*g:\symbols*http://msdl.microsoft.com/download/symbols -pn sqlservr.exe

你必须确保只有一个SQL Server实例在运行,因为WinDbg是通过进程名称sqlservr.exe来附加的。如果你有多个SQL Server实例运行,你要指定正确的PID,这个可以从任务管理器拿到。

使用如下的命令:

windbg -y srv*g:\symbols*http://msdl.microsoft.com/download/symbols -p 384 

路径g:\symbols是你电脑上的位置,用来存储下载的符号表。那个位置的大小会改变,因为你会不停的下载大量的符号文件。我本地的符号文件现在有1G的大小……如果一切正常,你现在应该可以附加到sqlservr.exe:

程序执行现在已经停止了,因为你碰到了ntdll模块里的断点。ntdll是系统提供的一个简单的封装DLL,用来进行用户模式到内核模式的转换。这也意味着现在SQL Server里的“每个”线程都已经停止了,不能进行任何操作!!!请不要尝试在生产环境里将WinDbg附加到sqlservr.exe!!如果你像恢复sqlservr.exe的运行,按键盘上的F5即可——SQL Server就再次恢复运行了。如果你想再次中断程序执行,你需要设置sqlservr.exe的进程空间里的断点,或者通过键盘快捷键CTRL+BREAK。

如果你用那个快捷键中断运行,WinDbg会把你放在sqlservr.exe的某个特定线程上。如果你想分析特定内存地址或者像设置具体断点用作进一步的故障排除,推荐你这么做。在WinDbg里一个非常重要呢个的命令是x命令:它会返回你指定模块里所有定义的符号。我们来看下面的命令:

x sqlmin!*BTree*

这个WinDbg命令会返回你所有名称包含“BTree”的函数名列表。这样的话,你就可以在指定的函数名上设置断点进行分析。返回函数名称如下格式:

module_name!class_name::function_name

例如sqlmin!BTreeMgr::Seek。如果你像返回BTreeMgr类定义的所有函数,可以使用下列命令:

x sqlmin!BTreeMgr::*

X命令是一个非常强大的命令,用来探索SQL Server实现的各个类。给你留点家庭作业,回答下列问题:

  • 哪个类里实现了锁管理器(Lock Manager)? sqlmin!LockManager::*
  • 哪个函数用来获得和释放闩锁(latches)? sqlmin!BUF::AcquireLatch和sqlmin!BUF::ReleaseLatch
  • 哪个类名实现SQLOS的调度? sqldk!SOS_Scheduler

欢迎在评论里回答上述问题。

小结

这篇文章我已经给你介绍了WinDbg的入门,还有你如何使用这个调试器附加到SQL Server。你已看到,sqlservr.exe进程空间里包含多个DLL文件,在那里每个DLL实现了SQL Server的各个组件功能。当你已经正确配置好公共符号的路径,你就可以获得组成SQL Server的各个类和函数的元数据信息。这里WinDbg的x命令是你的好助手。

希望你会喜欢这个特别的文章,下次我会为你介绍如何使用WinDbg指令来调试和执行SQL Server查询。

感谢关注!




贵州旅游线路报价贵州旅游攻略大全贵州旅游路线推荐贵州自驾游攻略贵州旅游线路大全桂林神龙水世界电话?神龙水世界景区团购多少钱? 桂林神龙水世界景区几点开门?神龙水世界开门时间? 桂林神龙水世界度假怎么样?神龙水世界景区有什么好玩的? 桂林神龙水世界两日游攻略?神龙水世界两日游费用? 白水寨景区山花开了吗?2015增城白水寨赏花攻略? 白水寨紫荆花最佳观赏时间?增城白水寨紫荆花几月份最好看? 白水寨紫荆花开了吗?增城白水寨景区紫荆花开花时间? 2015三八妇女节东莞龙凤山庄门票多少?东莞龙凤山庄门票3.8女士免费吗? 沈阳公馆四站游 领略老建筑之美 背上行囊走安徽 背包客十大必游经典线路 郭沫若与鼋头渚的故事 秀色可餐游康定 美食难挡味觉享受 马尔代夫卡尼岛和 满月岛哪个更适合度蜜月? 泰国皇帝岛深潜注意事项有那些? 去泰国需要提前换多少泰铢? 机场去曼谷宜必思娜娜酒店怎么走?有多远? IDT72V3650L15PF8 Datasheet IDT72V3650L15PF8 Datasheet IDT5V9910A-5SOGI Datasheet IDT5V9910A-5SOGI Datasheet IDT71V3558XS133PFI8 Datasheet IDT71V3558XS133PFI8 Datasheet 内蒙古到香港澳门旅游价格 内蒙古到香港澳门旅游价格 内蒙古到香港澳门旅游价格 四平到香港澳门旅游价格 四平到香港澳门旅游价格 四平到香港澳门旅游价格 长春到港澳4日游 长春到港澳4日游 长春到港澳4日游