一、前言

在规模稍微大点的项目中,为了方便快速找到bug的所在,我们往往需要在代码中加入一些调试用的代码,比如加入一些printf,打印出一些重点的信息;加入assert,进行断言判断。这些比较随意的调试代码会使整个系统显得比较凌乱。于是Fred Fish开发了一套用于嵌入代码中的库,开发人员只需要调用相应的函数即可加入调试信息。

对于MySQL这种多线程的程序来说,调试也是比较困难的,MySQL选择了DBUG作为其调试代码(在原始代码的基础上进行了略微的改造),充分说明了DBUG的实用性,本文就DBUG的原始代码进行介绍。

二、DBUG下载与使用

这里以linux下的开发进行介绍。

首先需要下载DBUG源码,下载地址:http://sourceforge.net/projects/dbug/

解压后在dbug/src下即是debug所需的源码文件:dbug.h dbug.c

dbug/example.c是一个简单的例子,源码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/*
 * This file is Public Domain
 *
 * Just short example, how Fred Fish's dbug package should be used
 *
 * Tonu Samuel <tonu @spam.ee="">
 *
 */
#include "dbug.h"
static int sub1 (void);
static void sub2 (char *arg);
static int
sub1 (void)
{
  DBUG_ENTER ("sub1");
  sub2 ("Hello world!");
  sub2 ("Hello earth!");
  sub2 ("Hello programmer!");
  DBUG_RETURN (0);
}
static void
sub2 (char *arg)
{
  DBUG_ENTER ("sub2");
  DBUG_PRINT ("info", ("Got argument: '%s'", arg));
  printf ("%s\n", arg);
  DBUG_VOID_RETURN;
}
int
main (void)
{
  int ret = 0;
  DBUG_PUSH ("d:t:O");
  DBUG_PROCESS ("example");
  ret = sub1 ();
  DBUG_PRINT ("info", ("Returned value: %d", ret));
  return 0;
}</tonu>

我们将example.c放到src目录下,然后编译example文件:

1
dbug/srcgcc -Wall -g dbug.c example.c -o example

运行example输出如下:

1
2
3
4
5
6
7
8
9
10
11
>sub1
| >sub2
| | info: Got argument: 'Hello world!'
Hello world!
| <sub2 |="">sub2
| | info: Got argument: 'Hello earth!'
Hello earth!
| <sub2 |="">sub2
| | info: Got argument: 'Hello programmer!'
Hello programmer!
| <sub2 pre="" 0="">< value: Returned info: <sub1></sub1></sub2></sub2></sub2>

结合源码,我们通过打印出来的信息,可以很容易的看出调试信息所表达的意思:

函数sub1调用了三次sub2,三次的参数分别是'Hello world!' ,'Hello earth!' ,'Hello programmer!' ,最后return 0.

下面初略介绍下上面用到的几个宏定义:

DBUG_PUSH ("d:t:O");  设置调试的启动参数,参数列表在MySQL手册上也有:

标记 描述
d

允许对当前状态从DBUG_<N>宏输出。可能跟着一列关键词,这些关键词仅对那些带有 
关键词的DBUG宏选择输出。一个空的关键词列意味着对所有宏输出。

D

在每个调试起输出行后延迟。参量一个十分之一秒为单位来延迟的数,它受限于机器的能 
力。比如 -#D,20 指定一个2秒的延迟。

f

限制调试和/或跟踪,以及简单设定于列出名字的函数。注意,空列将禁止所用函数。应 
该给出适当的d 或 t 标记,如果它们被允许了,这个标记仅限制它们的动作。

F 对调试或跟踪输出的每一行识别源文件名。
i 对调试或跟踪输出的每一行用PID或线程ID识别进程。
g

允许解析,创建名为的dbugmon.out文件,它包含可用来简单设定程序的信息。可能跟着 
一列关键词,它们是选择只对列中的函数做简单设定。一个空列意味着所有函数都要考虑 
到。

L 为调试或跟踪输出的每一行识别源文件行号。
n 为调试或跟踪输出的每一行打印当前函数嵌套深度。
N 给调试输出的每一行编号。
o 重定向调试器输出流到指定文件。默认输出是stderr 文件。
O

类似于 o,但是文件在每次写操作之间被冲刷。当需要之时,文件在每次写操作之间被关 
闭然后重新打开。

p

限制调试器作用于指定进程。为使调试器动作,一个进程必须用DBUG_PROCESS宏来识 
别,且匹配列表中的一个。

P 为调试或跟踪输出的每一行打印当前进程名字。
r

当推出一个新状态时,不继承前状态的操作嵌套深度级别。当输出在左边空白开始时有 
用。

S

在每个调试过的函数做_sanity(_file_,_line_)函数直到 _sanity() 返回不同于0的结果。(大多 
数的时候与safemalloc 一起用来找出内存漏洞)。

t

允许函数调用/退出跟踪行。可能跟着一个给出最大跟踪级别的数字列(只含一个修改 
量),超过这个数字,调试中或跟踪中的宏不能产生任何输出。 默认为一个编译时间选 
项。

DBUG_PROCESS ("example"); 设置进程名为example

DBUG_ENTER ("sub1"); 表示进入函数sub1

DBUG_PRINT ("info", ("Got argument: '%s'", arg)); 和printf效果差不多,打印出需要的调试信息。

DBUG_RETURN (0);  在return 0 的基础上,打印出return 0的调试信息。

三、小结

本文简单介绍了DBUG的使用方法,没有深究,源码很少,却很实用,在源码的注释部分,我看到了是Fred Fish1987年写的,呃,我才刚出生....,没想到现在还在看那时候的代码,可能这就是所谓的经典吧。

兄弟们,你们还在为复杂环境下的bug调试而苦恼么?还在为堆栈被写乱掉无从下手而凌乱么?淡定吧,一起来用DBUG吧~~

踏着落叶,追寻着我的梦想。转载请注明出处

MySQL源码学习——DBUG调试相关推荐

  1. Mysql源码编译和调试debug

    下载源码 直接从github 上下载了源码.git 地址:https://github.com/mysql/mysql-server 下载路径如:/work/mysql-server 编译 依赖 ma ...

  2. Mysql源码学习——八度空间

    学习完词法分析和语法分析后,开始进入Mysql源码的正式学习之旅了.这么多模块,肿么入手呢?!还好从网上搜到了一个模块划分,以后就尽可能根据这个模块划分一步一步的跟踪源码,揭开Mysql的面纱. 我们 ...

  3. Win7+VS2010:mysql 源码编译与调试

    win7+vs2010源码编译mysql 最近由于在实习,工作重点在于一些数据库的开发,为了更好的理解数据库的实现机制,目前萌生了要研究一下mysql数据库源码的想法.那么好吧,说干就干,首先我们需要 ...

  4. mysql源码学习 vc项目解决方案文件_Mysql源码学习——源码目录结构

    目录清单 目录名 注释 Bdb 伯克利DB表引擎 BUILD 构建工程的脚本 Client 客户端 Cmd-line-utils 命令行工具 Config 构建工程所需的一些文件 Dbug Fred ...

  5. Mysql源码学习——源码目录结构

    目录清单 目录名 注释 Bdb 伯克利DB表引擎 BUILD 构建工程的脚本 Client 客户端 Cmd-line-utils 命令行工具 Config 构建工程所需的一些文件 Dbug Fred ...

  6. Mysql源码学习——Thread Manager

    一.前言 上篇的Connection Manager中,曾提及对于一个新到来的Connection,服务器会创建一个新的线程来处理这个连接. 其实没那么简单,为了提高系统效率,减少频繁创建线程和中止线 ...

  7. MySQL源码学习:MySQL中禁止跨库访问的实现

    摘要:  先说一下这里"跨库"的意思:当前use的是db1, 仍可以使用select * from db2.table1来访问table1表. 这样使得我们需要访问同一个MySQL ...

  8. mysql 源码 sln_在windows下使用vs2013编译和调试mysql源代码

    在windows下使用vs2013编译和调试mysql源代码 1. 准备工作 1)OS:win10 + VS2013 2)mysql 源码(windows版):mysql-5.6.25.zip 3)p ...

  9. 【附源码】计算机毕业设计Python安卓少儿英语在线学习平台APPodto4(源码+程序+LW+调试部署)

    [附源码]计算机毕业设计Python安卓少儿英语在线学习平台APPodto4(源码+程序+LW+调试部署) 该项目含有源码.文档.程序.数据库.配套开发软件.软件安装教程 项目运行环境配置: Pyth ...

最新文章

  1. python 栈_Python数据结构与算法05:基本结构:栈的应用之括号匹配
  2. JMM内存模型如何为并发保驾护航
  3. css:text-align:justify的用法
  4. Codechef SEAARC Sereja and Arcs (分块、组合计数)
  5. why is list delete and edit icon rendered
  6. 求生欲强烈!HTC官方回应并未退出中国市场
  7. spark yarn 提交作业
  8. java 获取文件的全路径
  9. ARouter 源码历险记 (四)
  10. MATLAB下载安装
  11. 再问运费查询的具体实现问题
  12. 在华为手机上查看连接过的wifi密码(不愁记性不好)
  13. 最好的评价线性回归的指标-R Squared
  14. Mongodb入门(CRUD与安装)
  15. 技术支持快递第6 期
  16. 探针台的配件也要第三方计量校准吗
  17. 40了解云计算平台的高可用架构,如 AWS 的多可用区、GCP 的负载均衡器
  18. 学习笔记:使用endnotesX9插入参考文献
  19. ffmpeg播放器声音效果2-变速不变调及变调
  20. 源码编译系列之mpv播放器编译教程

热门文章

  1. MFC Windows编程模型
  2. HP-UNIX操作系统root账号被锁定的两种解决方法
  3. Sherman-Morrison公式及其应用
  4. Linux系统文件有三个主要的时间属性,分别是ctime(change time), atime(access time), mtime(modify time)...
  5. SAP面向iOS设备推Cloud Platform SDK工具
  6. BZOJ 2720 [Violet 5]列队春游 ——期望DP
  7. Consul入门04 - Consul集群 1
  8. #敏捷个人#每日认识101(15):成为一个有执行力的人
  9. eclipse中显示jquery或extjs自动提示
  10. 禁止snmpd往syslog中写入无用信息