clion怎么调试postgresql呢?
clion使用cmake去编译项目的,但是大家编译postgresql用的是make。虽然项目中也有CMakeLists.txt文件,但是cmake会报错,因此我们要修改使用cmake调用make去做编译,就好像在java中用maven调用ant编译一样。
安装步骤
- 把源码从git上clone下来
- 安装依赖库:readline、bison和flex等
- 运行
sh configure --prefix=$HOME/project --enable-depend --enable-cassert --enable-debug
把其中的$HOME/project
改成你想安装postgresql的目录
- 运行make
- 运行make install
- 使用initdb初始化数据库,指定数据目录
- 使用Clion导入postgresql源码
- 修改CMakeLists.txt,内容如下(如果没有,可以直接创建,并将下放内容复制进去)
cmake_minimum_required(VERSION 3.6)
project(postgres)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")
add_custom_target(postgres COMMAND make -C ${postgres_SOURCE_DIR})
- 打开debug configuration,增加一个Application,Target选postgres,Executable选择到源码目录的
src/backend/postgres
,程序参数写 -D 数据目录
然后就可以愉快的调试代码了,主函数在src/backend/main/main.c
调试过程中,发现断点乱跳,而且在Eclipse/CDT中查看部分变量的值的时候,出现optimized字样。怀疑是编译过程中的优化导致的,为此需要关闭gcc优化选项。
在https://wiki.postgresql.org/wiki/Developer_FAQ文章中也提到关闭优化开关,实践下来,configure的参数如下:
./configure --prefix=%your project path% --enable-depend --enable-cassert --enable-debug CFLAGS="-ggdb -O0"
目前看来貌似解决了断点乱跳的问题