mysql 源码阅读_MySQL5.7.13源代码阅读心得

1.使用gdb这个调试工具。

在linux使用该调试工具非常简单。它的价值非常大,可以告诉你函数相互调用的逻辑(bt命令),告诉你函数执行的情况(通过br命令以及n,c命令单步跟踪函数每一个语句的执行),告诉你每个函数变量的值(p命令)。

(1)首先打开mysql服务器 ./mysqld

(2)重新开始一个客户端,打入mysql -uroot -p,输入密码进入mysql,以下称mysql客户端

(3)重新开始一个客户端,打入ps -ef|grep mysql找出mysql的pid,以下称gdb客户端

5531e406b1c44c3e9b590c9a6b2cdff8.png

这里mysql的pid是32047,因此打入命令gdb --pid 32047,进入gdb调试界面

(4)设置断点 br  table_global_status::rnd_init

(5)回到mysql客户端,打入show global status

(6)回到gdb客户端,打入c命令,然后我们可以看到程序在我们想要的位置停下,

51cd0d2956f8c94a70a076f879f43edc.png

(7)接下来我们就可以使用bt命令查看

06376f5dcdf20069bc966b214841fa19.png

(8)接着可以使用p命令,n命令都可以用来调试相应的代码

2.使用好的文件阅读工具,我用的是subline text 3,相信大多数的前端同学都会使用这个工具

可以进行全局搜索,比如对于show global status的命令可以搜索show_global_status,因为mysql好像采用的是谷歌命名法就有意想不到的收获

3.查看mysql代码可以通过文件名字判断mysql代码的功能。

最后不得不吐槽下mysql代码虽然写的更好,但是还是比较坑爹,他还是大量地使用了函数指针来简化他的代码,使我们这些读代码的人比较困惑。。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值