clion调试postgresql

clion怎么调试postgresql呢?

clion使用cmake去编译项目的,但是大家编译postgresql用的是make。虽然项目中也有CMakeLists.txt文件,但是cmake会报错,因此我们要修改使用cmake调用make去做编译,就好像在java中用maven调用ant编译一样。

安装步骤

  1. 把源码从git上clone下来
  2. 安装依赖库:readline、bison和flex等
  3. 运行
sh configure --prefix=$HOME/project --enable-depend --enable-cassert --enable-debug

把其中的$HOME/project改成你想安装postgresql的目录

  1. 运行make
  2. 运行make install
  3. 使用initdb初始化数据库,指定数据目录
  4. 使用Clion导入postgresql源码
  5. 修改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})
  1. 打开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"

 

目前看来貌似解决了断点乱跳的问题

 

 
 
posted @   邱明成  阅读(3002)  评论(1编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
历史上的今天:
2018-04-19 AJAX POST请求中参数以form data和request payload形式在servlet中的获取方式
2018-04-19 SpringMVC中使用Interceptor拦截器
2018-04-19 js拦截全局ajax请求
2016-04-19 分布式搜索方案选型
2016-04-19 MySQL分库分表环境下全局ID生成方案
点击右上角即可分享
微信分享提示