首页 > 其他分享 >使用clion远程调试openGauss

使用clion远程调试openGauss

时间:2024-08-15 15:19:51浏览次数:17  
标签:code zhoubin -- work debug home openGauss clion 调试

一、前言

openGauss数据库默认在linux系的操作系统上编译和运行,要想可视化调试运行,要么换linux系的桌面系统、要么在命令行使用gdb进行调试。而我习惯使用windows办公,所以非常想通过clion远程调试功能来实现在windows上的openGauss开发与调试。对比gdb,可以在调试的时候直接查看或者跳转函数/变量定义,提升代码效率。

二、环境准备

本次利用clion的cmake和deployment功能实现远程调试,相关配置及规划如下:

1.可以正常编译openGauss的linux服务器一台(openEuler 20.03 LTS(aarch64)),已安装相关的依赖,参考openGauss源码编译:链接,磁盘空间充足。

2.windows机器一台,已安装clion(版本:2024.1.4),可以通过ssh远程到linux服务器。(clion 2020版本无法关联代码,请避雷)

三、下载openGauss编译用源代码

1. windows端

a.下载代码前勿必先执行git config --global core.autocrlf false ,禁止crlf的自动转换。

注意:这个配置默认是true,请使用空目录下载。

b.下载openGauss-server源代码git clone https://gitee.com/opengauss/openGauss-server.git

本次假定代码下载到E:\code\gitee\openGauss-server目录

2. linux端

可以通过clion配置Deployment功能自动上传,不过为了方便代码修改追踪,仍然建议直接使用git下载代码。

另外三方库也需要下载,本次使用7.3版本,本次假定路径:/home/zhoubin/work/binarylibs

本次假定代码下载到/home/zhoubin/work/remote_debug/code

四、配置Linux端的cmake编译环境

直接在linux下的~/.bashrc文件下补充以下配置:

MY_HOME=/home/zhoubin/workexport DEBUG_TYPE=debugexport ARCH=aarch64export GCC_VERSION=7.3.0
export THIRD_BIN_PATH=$MY_HOME/binarylibsexport JAVA_HOME=$THIRD_BIN_PATH/openjdk8/${ARCH}/jdk/export PATH=$PATH:${JAVA_HOME}/binexport APPEND_FLAGS="-g3 -w -fPIC"export GCCFOLDER=$THIRD_BIN_PATH/buildtools/gcc7.3export CC=$GCCFOLDER/gcc/bin/gccexport CXX=$GCCFOLDER/gcc/bin/g++export LD_LIBRARY_PATH=$GCCFOLDER/gcc/lib64:$GCCFOLDER/isl/lib:$GCCFOLDER/mpc/lib/:$GCCFOLDER/mpfr/lib/:$GCCFOLDER/gmp/lib/:$LD_LIBRARY_PATHexport LD_LIBRARY_PATH=$THIRD_BIN_PATH/dependency/kerberos/comm/lib:$LD_LIBRARY_PATHexport LD_LIBRARY_PATH=$THIRD_BIN_PATH/dependency/libcgroup/comm/lib:$LD_LIBRARY_PATHexport LD_LIBRARY_PATH=$THIRD_BIN_PATH/dependency/openssl/comm/lib:$LD_LIBRARY_PATHexport LD_LIBRARY_PATH=$THIRD_BIN_PATH/dependency/libcurl/comm/lib:$LD_LIBRARY_PATHexport PATH=$GCCFOLDER/gcc/bin:$PATHexport PREFIX_HOME=${MY_HOME}/remote_debug/code/destexport GAUSSHOME=$PREFIX_HOMEexport PATH=$GAUSSHOME/bin:$PATHexport LD_LIBRARY_PATH=$GAUSSHOME/lib:$LD_LIBRARY_PATH

重新source ~/.bashrc后,验证是否可以通过cmake编译:

cd /home/zhoubin/work/remote_debug/codemkdir cmake_buildcd cmake_buildcmake .. -DENABLE_MULTIPLE_NODES=OFF -DENABLE_THREAD_SAFETY=ON -DENABLE_MOT=ON && make -sj20 && make install -sj

正常编译的结尾日志如下:

-- Created symlink: libatomic.so -> libatomic.so.1.2.0-- Created symlink: libatomic.so.1 -> libatomic.so.1.2.0-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libsecurec.so-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libgcc_s.so.1-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libgomp.so-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libgomp.so.1-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libgomp.so.1.0.0-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libxgboost.so-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libpljava.so-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/postgresql/java/pljava.jar-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/share/postgresql/tmp/udstools.py-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/./lib-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/./lib/libmasstree.so-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib-- Installing: /home/zhoubin/work/remote_debug/code/dest/lib/libatomic.so-- Installing: /home/zhoubin/work/remote_debug/code/dest/lib/libatomic.so.1-- Installing: /home/zhoubin/work/remote_debug/code/dest/lib/libatomic.so.1.2.0-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libgcc_s.so.1-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libgomp.so.1-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libgomp.so.1.0.0-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libgomp.so-- Created symlink: libcgroup.so.1 -> libcgroup.so-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/share/postgresql/extension/roach_api_stub.control-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/share/postgresql/extension/roach_api_stub--1.0.sql-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/postgresql/proc_srclib-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/postgresql/pg_plugin-- Up-to-date: /home/zhoubin/work/remote_debug/code/dest/lib/libsimsearch

为了更好的支持多线程调试,应该安装debuginfo相关安装包:

yum install glibc-debuginfo-2.28-36.oe1.aarch64 -ydnf debuginfo-install libxcrypt-4.4.8-4.oe1.aarch64 xz-libs-5.2.5-1.oe1.aarch64 -ydnf debuginfo-install glibc-2.28-63.oe1.aarch64 -y

五、Clion配置

1. 配置远程服务

进入clion菜单File->Settings->Tools->SSH Configurations,添加一个linux的远程连接,下面的几个服务都会用到。

图片

2. 配置Deployment

Deployment用于同步windows和linux之间的文件(含代码),进入clion菜单File->Settings->Build,Execution,Deployment,配置如下:

图片

这个页面的Mappings需要配置windows和linux的映射, Excluded Paths配置不需要同步的文件目录。

图片

3. 配置Toolchains

Toolchain主要是配置远程编译工具链,通过File->Settings->Build,Execution,Deployment->Toolchains,配置如下:

图片

注意:gdb版本要高于gcc版本,本次gdb版本为8.3.1,gcc使用社区的7.3.0。

4. 配置cmake

cmake用于远程配置工程并自动编译,进入File->Settings->Build,Execution,Deployment->CMake,配置如下:

图片

针对openGauss的CMake参数:

-DENABLE_MULTIPLE_NODES=OFF -DENABLE_THREAD_SAFETY=ON -DENABLE_MOT=ON

针对openGauss的CMake环境变量,相关路径在3.2有说明,实际配置时相对替换掉就行:

DEBUG_TYPE=debug;ARCH=aarch64;GCC_VERSION=7.3.0;THIRD_BIN_PATH=/home/zhoubin/work/binarylibs;PATH=/home/zhoubin/work/binarylibs/buildtools/gcc7.3/gcc/bin:$PATH;APPEND_FLAGS="-g3 -w -fPIC";GCCFOLDER=/home/zhoubin/work/binarylibs/buildtools/gcc7.3;CC=/home/zhoubin/work/binarylibs/buildtools/gcc7.3/gcc/bin/gcc;CXX=/home/zhoubin/work/binarylibs/buildtools/gcc7.3/gcc/bin/g++;LD_LIBRARY_PATH=$THIRD_BIN_PATH/dependency/libcurl/comm/lib:$LD_LIBRARY_PATH;PREFIX_HOME=/home/zhoubin/work/remote_debug/code/dest;GAUSSHOME=$PREFIX_HOME;BUILD_TUPLE=aarch64;JAVA_HOME=$THIRD_BIN_PATH/openjdk8/${ARCH}/jdk/

5. cmake project load

以上配置完成后,底部的CMake页签会自动进行向linux服务器Deployment工程代码,并进行远程CMake编译:

图片

如果没有自动触发,可以手动在页签上进行刷新,等编译完成,详情日志如下:

-- /home/zhoubin/work/remote_debug/code/home/zhoubin/work/remote_debug/code/cmake_build_debug/home/zhoubin/work/remote_debug/code/dest-- Configuring done-- Generating done-- Build files have been written to: /home/zhoubin/work/remote_debug/code/cmake_build_debug

6. install

CMake远程编译无问题后,最后一步是通过菜单Build->install完成openGauss远程安装,接下来就可以进行可视化调试了:

图片

等待install完成后(编译完成日志与linux下直接cmake编译一致),可以看到右边的调试栏里所有的openGauss的程序已经进入可运行状态,这样就可以选择任意组件进行调试了。

六、调试pg_config

选择pg_config

在可调试窗口选择pg_config,本次简单执行pg_config --help验证代码是否可以正常断点和执行。

图片

启动前断点打在src\bin\pg_config\pg_config.cpp的main函数第一行,启动调试,可以看到正确进入到断点,堆栈和变量窗口已经可视化:

图片

在断点后的单步/步入/步出/全速执行均可正常执行,现在远程调试功能已经ready。

七、调试gaussdb

这一步就是最关键的gaussdb进程的调试了,在进入调试前应该先在本次关联的服务器上先初始化好数据库,再通过参数正确的启动数据库。

1. 初始化数据库

本步骤需要到linux服务器上执行,选择数据库目录为/home/zhoubin/work/tmp/1,执行下面的命令即可初始化一个数据库:

mkdir -p /home/zhoubin/work/tmp/1gs_initdb -D /home/zhoubin/work/tmp/1 --nodename=test -w Test@123

初始化完成后会提示使用gaussdb -D /home/zhoubin/work/tmp/1 --single_node命令启动数据库,这几个参数即为下一步的入参。

提示:默认的端口5432容易被抢占,建议修改新的端口:

gs_guc set -D /home/zhoubin/work/tmp/1 -c "port=6123"

2. 启动gaussdb调试

先选择gaussdb目标,并配置执行参数:

图片

注意:如果确定本次并没有修改代码,可以将Before launch中的Build步骤删除,不然每次启动调试都要重新构建,非常耗时间!

下一步断点打在src\gausskernel\process\main\main.cpp的main函数第一行,打完断点即可启动调试:

图片

可以看到断点进入了,并且常用的上下文变量g_instance\t_thrd\u_sess(手工添加的)都可视化了:

图片

下一步全速执行时,突然断在了__poll函数,这是因为自定义的SIGUSR2信号被触发了,可以在gdb窗口执行handle SIGUSR2 nostop noprint 使进程继续执行:

图片

现在就可以在可视化界面任意打断点、调试验证了。一起来参与openGauss内核代码贡献吧!!!

八、FAQ

本次搭建环境出了各种各样的错误,还是将遇到的问题做个记录。

1. 第五步cmake project load的CMake窗口提示"Cannot reslove path"

图片

原因: Clion版本bug,链接, Deployment的root path和Mappings配置已经失效。

解决方法: 替换Clion新版本或者重启Clion后删除旧的Deployment,重新配置一次(建议换新版本,别在这折腾了)。

2. cmake各种莫名其妙的报错

解决方法:在CMake配置界面,增加--trace参数,然后查看cmake日志分析。

3. 调试时提示"warning: Unable to find libthread_db matching inferior's thread library, thread debugging will not be available"

解决方法:编辑~/.gdbinit文件,添加下面内容:

set auto-load safe-path /add-auto-load-safe-path /lib64/libthread_db-1.0.so

4. 提示某个变量的长度超限,可以在gdb窗口执行`set max-value-size unlimited`取消限制。当然所有的gdb命令都可以填到~/.gdbinit文件中,避免每次调试都要输一遍。

标签:code,zhoubin,--,work,debug,home,openGauss,clion,调试
From: https://www.cnblogs.com/renxyz/p/18360937

相关文章

  • Zabbix与openGauss的深度融合
    前言Zabbix与openGauss的深度融合1.openGauss可观测架构介绍openGauss是一款企业级开源关系性数据库。在企业的生产系统中,数据库一般位于上层应用和操作系统中间的位置。上层应用通过数据库处理分析数据,数据库与操作系统紧密结合,利用高效的存储硬件,对数据进行安全可靠的存放。如......
  • Java、python、php版的宠物美容预约服务系统的设计与实现 (源码、调试、LW、开题、PPT)
    ......
  • 基于SpringBoot的心理健康管理系统的设计与实现(源码+LW+调试文档)
    目录:程序视频演示:程序技术介绍:后端springboot介绍:mysql介绍:程序功能截图:程序部分代码参考:数据库sql:程序论文:​选择我的理由:程序获取:......
  • 钉钉微应用开发调试竟如此简单 (包含内网穿透,也适应微信网页开发调试)
    一、前言最近在将一个H5项目迁移至钉钉应用,在引入钉钉相关能力的时候(如:接入H5微应用系统免登),需要在钉钉的沙箱环境下才能执行相关操作。但是在钉钉沙箱环境中Log日志、request请求,缓存数据,无法直接查看,这对开发阶段带来了极大的困扰,经过翻阅文档整理出针对钉钉开发环境......
  • openGauss怎么工作SQL函数接口读取逻辑解码结果?
    功能描述在openGauss中如果实现数据复制呢?可以通过数据迁移工具定期向目标数据库进行数据库的同步,说的定期,这就意味着这种方式不能满足数据实时复制的需求。在openGauss中为我们提供了逻辑解码功能,工作原理就是反解xlog,从而生成逻辑日志,在目标数据库中通过对逻辑进行解析......
  • BUG[系列]:imx6ull调试ADC功能。
    一、前言产品上有一个声控开关的需求,需要用到ADC,调试过程遇到了很多问题,特此记录下。(都可以写个小故事了)二、过程1.修改设备树板子上ADC功能默认是没有打开的,所以先改设备树。1.1BUG1:从doc文档直接复制代码,格式错误,编译和运行不会报错。描述:我直接从doc文档把ADC设备树代......
  • SSM基于的社区疫情防控管理信息系统的设计与实现khjit 本系统(程序+源码+数据库+调试部
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表系统内容:居民,核酸检测,检测预约,检测记录,健康上报,出入信息,物品申请,物品派送开题报告内容一、课题背景与意义随着全球新冠疫情的持续蔓延,社区疫情防控成为......
  • 丢掉数据线,你还会调试Android设备吗?
    ADB(Android Debug Bridge)作为Android开发中非常重要的工具,开发者可以使用ADB设备在电脑上对Android设备进行安装调试应用。通常我们使用ADB调试时需要USB数据线进行连接,当Android设备USB接口出现问题或身边没有USB数据线时,使用WiFi调试Android设备便成为了一种实用的替代方案。......
  • JSP花店业务管理系统的设计与实现4vcg5--(程序+源码+数据库+调试部署+开发环境)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表系统功能:用户,商家,场合分类,花卉信息,商家回复,用户咨询开题报告内容一、项目背景与意义随着人们对生活品质追求的提升,花卉消费日益增长,传统花店管理模式已难......
  • JSP河南口腔医疗诊所线上服务系统a11h1--程序+源码+数据库+调试部署+开发环境
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表系统功能:用户,医生,科室,医生信息,挂号信息,药品信息,取消挂号开题报告内容一、课题名称河南口腔医疗诊所线上服务系统设计与实现二、研究背景与意义随着互......