Clickhouse 源码编译 Debug 指导手册

本文详述了在Ubuntu22环境下使用IntelliJClion进行ClickHouse源码编译,包括环境配置(如proxy设置、CMake与Ninja)、解决内存不足问题、gdbserver远程调试的全过程。
摘要由CSDN通过智能技术生成

在这里插入图片描述

https://www.mrhan.icu

本文主要介绍Clickhouse 源码编译的指南

开发环境

  1. 开发工具:Intellij Clion 开发工具
  2. 操作系统:Ubuntu 22 系统
  3. 编译所需内存:建议是32G 内存
  4. 编译环境:clang-16 gcc nasm yasm
  5. 构建关系:CMake Ninja
  6. 调试工具:gdb-server
  • llvm clang 下载地址: https://github.com/llvm/llvm-project/releases/tag/llvmorg-16.0.3

1. 环境准备

eg: 如果网络环境比较不Ok的可以先配置上代理:
export HTTP_PROXY=http://192.168.0.111:7890
export HTTPS_PROXY=http://192.168.0.111:7890

  1. 拉取源代码:
git clone https://github.com/ClickHouse/ClickHouse.git

在这里插入图片描述

cd Clickhouse
# 更新所有clickhouse 所需要的git submodules 如果这一步出现网络超时或者其他情况, 建议配置代理并且多执行几次
git submodule update --init -f
ls -l
# 新建build 目录
mkdir build
cd build
# cmake 生成构建脚本 需要使用 llvm-clang 进行编译 禁止 ccache
cmake -DCMAKE_BUILD_TYPE=Debug -DCMAKE_C_COMPILER=clang-16 '-DCMAKE_CXX_COMPILER=clang++-16' -G Ninja -DLINKER_NAME=ld -DCOMPILER_CACHE=disabled ..

在这里插入图片描述

  1. 环境检测成功后,可以进行编译
# ninja 进行编译 -j 8 8个 job 同时进行
ninja -j 8

在这里插入图片描述

  1. 编译过程中可能会出现这个错误:
    在这里插入图片描述

这个错误是因为 在 执行 linker阶段内存不够导致的。可以通过开启 swap 或者 扩大内存来解决这个问题。

具体如何扩大 swap 交换区可以自行百度

sudo fallocate -l 20Gb /helloswap
sudo chmod 600 /helloswap
sudo mkswap /helloswap
sudo swapon /helloswap
  1. 编译成功,启动!

2. 基于gdb server 远程调试

安装gdb gdb server

sudo apt-get install gdb gdbserver

生成Debug符号文件

objcopy --only-keep-debug ./programs/clickhouse ./programs/clickhouse.dbg

开启远程调试

# 启动程序
sudo gdbserver :1023 ./programs/clickhouse server

**使用 Clion 进行远程调试 **

环境准备: 打开源码

  1. 添加 Remote Debug

在这里插入图片描述

  1. 点击开始 DEBUG
    在这里插入图片描述

然后根据你的需求进行打断点,调试就可以了

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值