这篇文章我想探究下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命令是你的好助手。

本文转自Woodytu博客园博客,原文链接:http://www.cnblogs.com/woodytu/p/4663525.html,如需转载请自行联系原作者

使用WinDbg调试SQL Server——入门相关推荐

  1. 初次尝试使用Windbg调试Sql Server 进程

    最近看了吕海波大牛的书,和相关资料:决定尝试一下使用Windbg调试Sql Server 进程:当然是入门级的: 看了吕海波老师的书终于明白一个道理,原来数据库系统的内核(内存)中,就是各种链表: 大 ...

  2. 在Visual Studio 2005中调试SQL Server 2005的存储过程

    介绍 SQL Server 2000可以让我们在查询分析器中直接调试存储过程( 更多的信息请参看:用SQL Server 2000的查询分析器调试存储过程) 到了现在的SQL Server 2005, ...

  3. sql server 入门_SQL Server查询调整入门

    sql server 入门 This article will cover some essential techniques for SQL query tuning. Query tuning i ...

  4. sql server 入门_SQL Server中的数据挖掘入门

    sql server 入门 介绍 (Introduction) In past chats, we have had a look at a myriad of different Business ...

  5. oracle如何调试sql,调试oracle与调试sql server存储过程

    [IT168 技术]关于存储过程的调试,知道方法以后很简单,但在不知道的时候,为了测试一个存储过程的正性,print,插入临时表等可谓是使出了浑身解数,烦不胜烦.下面就把我工作中调试oracle存储过 ...

  6. sql server 入门教程

    sql server 入门教程 1.创建数据库 1)鼠标右键数据库选项,点击新建数据库 2)命名数据库 根据自己业务情况取一个自定义数据库名字,比如:my_database 3)查看数据库 如果添加没 ...

  7. sql server 入门篇

    sql server入门篇 一.创建数据库 二.修改数据库 三.删除数据库 四.数据表创建 五.数据表数据修改(增.删.改) 六.数据表查询 七.数据表操作 一.创建数据库 1.格式 CREATE D ...

  8. 调试SQL SERVER存储过程

    调试存储过程 出自:http://hi.baidu.com/fuhengyu/blog/item/0d7dbc4c624041fdd72afcbe.html 相关:在Visual Studio 200 ...

  9. SQL Server入门(四) 官网关于 SQL Server初级入门教程

    原文http://www.shareblogs.top/444/ 学习内容 这些教程将帮助你理解 SSMS 中提供的信息以及如何利用其功能. 熟悉 SSMS 的最好方式是进行实践演练. 这些教程将使你 ...

最新文章

  1. STM32学习笔记9(SysTick滴答时钟)
  2. 随机存取:fseek(),ftell()
  3. 【 Vivado 】XDC文件的约束顺序
  4. 可临摹学习的精致的音乐播放器界面设计ui模板
  5. ubuntu desktop的分辨率设置
  6. jsf入门实例_JSF selectManyListBox示例教程
  7. unity5, Configurable Joint: Anchor, Connected Anchor, Auto Configure Connected Anchor
  8. logstash 获取多个kafka_日志工程Logstash日志采集入门篇
  9. 自动开关机软件哪个好?自动开关机软件盘点
  10. matlab多元正态性检验,Matlab正态分布性检验
  11. CodeCademy | Python | 7. Function
  12. 论文阅读——Aspect Sentiment Quad Prediction as Paraphrase Generation
  13. 如何在Mac上卸载软件?用这三种方法简单、干净、快速
  14. 苹果手机3D-Touch这个功能,其实是吃鸡神器!
  15. springboot启动时,排除某些自动配置类
  16. Sentinel Dubbo 适配器看限流与熔断(实战思考篇)
  17. 使用域名注册服务 Domains配置域名【华为云至简致远】
  18. 计算机教育学专业考研科目,计算机考研科目和专业
  19. mysql外键约束分数_MySQL 高级查询
  20. 一个命令批量新建任意名称的文件夹

热门文章

  1. Android百度地图开发定位和路线导航
  2. 制作 macOS Sierra U盘USB启动安装盘方法教程 (亲测)
  3. 【kali-密码攻击】(5.1.2)密码在线破解:Medusa
  4. 甘超波:NLP心理学是什么?
  5. winlogon源码分析
  6. vue+axios+springboot文件下载(兼容IE10)
  7. c语言简单编程题目及答案,经典练习C语言编程的题目及答案整理.pdf
  8. 01、Flutter FFI 最简示例
  9. 6.20校内考试整理——大美江湖腐草为萤锦鲤抄题解
  10. pycharm 升级包版本