因为我本人主要是写Java的,有强烈的IDE依赖症,不喜欢使用文本编辑器或者命令行这样的工具,所以选择使用CLion搭建一个IDE环境来辅助阅读。但是CLion主要支持的是CMake管理的项目,而Redis是用普通的Makefile管理的,所以需要一些技巧来配置环境。
支持跳转
CLion从2018.2版本开始支持通过compiledb来让Makefile的项目支持跳转重构等高级功能。
首先安装compiledb:
pip install compiledb
务必在用CLion打开Redis项目之前进入Redis根目录,运行下面的命令:
compiledb -nf make
之后会在项目根目录下生成一个compile_commands.json
文件。
之后再用CLion打开Redis项目,这样CLion就会自动检测到compile_commands.json
,就可以读Redis源码时进行各种跳转了。
调试Redis
完成上面的步骤后,依旧只能把CLion当个阅读器来读代码,无法单步调试的话还是不方便理解源码。
经过一番研究,发现可以使用CLion的"GDB Remote Debug"的功能对Redis的二进制结合源码进行调试。
首先,要编译出一个专门用于debug的二进制,make
默认采用的编译优化级别的是-O2
,代码优化会影响我们调试,所以我们编译一个没有优化的版本便于调试:
make noopt
之后使用gdbserver
来执行该二进制(如果还有安装的话,就先安装gdbserver
):
gdbserver :43211 ./src/redis-server
上面命令表示在43211端口启动一个gdbserver
,用于调试二进制./src/redis-server
。
之后在CLion上进行配置Run -> Edit Configurations
:
打好断点,点击右上角的小虫子,就可以开心地调试Redis了。
调试的截图如下:
目前发现该调试方法的一个问题就是当gdbserver
退出后,它所启动的二进制进程依旧不会退出,需要手动kill一下,以免占用端口影响下次debug:
$ ps -ef | grep ./src/redis
dqyuan 11842 1 0 21:40 pts/5 00:00:00 ./src/redis-server *:6379
dqyuan 12266 26302 0 21:43 pts/2 00:00:00 grep --color=auto ./src/redis
$ kill -9 11842
参考文章
End
作者:元青
微信公众号 「技乐书香」