DEV Community

Cover image for Build clickhouse remote development environment with vscode(v24.8.11.5-lts)
abel-cheng
abel-cheng

Posted on

Build clickhouse remote development environment with vscode(v24.8.11.5-lts)

1 Build dev docker image

FROM docker.io/ubuntu:22.04
RUN rm /bin/sh && ln -s /bin/bash /bin/sh
RUN apt-get -y update
RUN apt-get install -y curl vim git ssh openssh-server cmake ccache python3 ninja-build nasm yasm gawk lsb-release wget software-properties-common gnupg
RUN ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa
RUN touch ~/.ssh/authorized_keys
RUN bash -c "$(wget -O - https://apt.llvm.org/llvm.sh)"
RUN echo "export CC=clang-18" >> /root/.bashrc
RUN echo "export CXX=clang++-18" >> /root/.bashrc
RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y
RUN echo "export PATH=~/.cargo/bin:$PATH" >> /root/.bashrc
RUN /root/.cargo/bin/rustup toolchain install nightly-2024-12-01
RUN /root/.cargo/bin/rustup default nightly-2024-12-01
RUN /root/.cargo/bin/rustup component add rust-src
Enter fullscreen mode Exit fullscreen mode

The rustup installation may fail due to network problems. Just try again, or write an automatic retry script.

After docker build, you will get a development image, named xxx-clickhouse-dev-env:24.8 in this article.

2 Download clickhouse code

git clone git@github.com:ClickHouse/ClickHouse.git <workspace>/clickhouse-24
cd <workspace>/clickhouse-24
git checkout v24.8.11.5-lts
Enter fullscreen mode Exit fullscreen mode

Download all submodules

#!/bin/sh
while :
do
git submodule update --init --recursive --force
sleep 1
done
Enter fullscreen mode Exit fullscreen mode

The loop is because the code clone is unstable and may fail.
When the actual clone does not appear in the log, manually kill the above process.

3 Set up development environment

remote development environment

docker run -itd --name xxx -v <workspace>/clickhouse-24:/data/clickhouse --privileged=true -p xxx:22 --cap-add="NET_ADMIN" --security-opt seccomp=unconfined xxx-clickhouse-dev-env-24.8 bash

Execute the following command in the docker container to enable ssh.

echo xxx >> ~/.ssh/authorized_keys # Write the token in your local id_rsa.pub
/etc/init.d/ssh start
Enter fullscreen mode Exit fullscreen mode

local development environment

Download vscode from https://code.visualstudio.com/.
Install extension remote-SSH next, then we can connect to remote server in vscode.

new ssh server entrance 1

new ssh server entrance 2

new ssh server entrance 3

Add a new ssh host in configuration like below.

Host clickhouse-24
    HostName <ip>
    User root
    Port <port>
Enter fullscreen mode Exit fullscreen mode

ssh connect
Then you can connect to the server as clickhouse-24, then open the code directory /data/clickhouse.

Next we need to install necessary extensions on remote server.

install extensions

Compile

Add .vscode directory in the working directory and a tasks.json file with the following contents:

{
    "version": "2.0.0",
    "tasks": [
        {
            "type": "shell",
            "label": "cmake",
            "group": "build",
            "command": "cmake -DCMAKE_BUILD_TYPE=Debug -DENABLE_CCACHE=1 -DCMAKE_C_COMPILER=/usr/lib/llvm-18/bin/clang -DCMAKE_CXX_COMPILER=/usr/lib/llvm-18/bin/clang++ -DCMAKE_PREFIX_PATH=/usr/lib/llvm-18/ -DENABLE_JEMALLOC=ON -DENABLE_TESTS=OFF -DCOMPILER_FLAGS=-DNDEBUG -DWERROR=OFF -G Ninja -B build",
            "options": {
                "cwd": "${workspaceFolder}"
            },
            "problemMatcher": [],
            "presentation": {
                "echo": true,
                "reveal": "always",
                "focus": true,
                "panel": "shared",
                "showReuseMessage": true,
                "clear": false
            }
        },
        {
            "type": "shell",
            "label": "ninja clickhouse",
            "group": "build",
            "command": "ninja clickhouse clickhouse-server clickhouse-client -j16",
            "options": {
                "cwd": "${workspaceFolder}/build"
            }
            // "dependsOn": "cmake",
            },
        {
            "type": "shell",
            "label": "ninja all",
            "group": "build",
            "command": "ninja -j16",
            "options": {
            "cwd": "${workspaceFolder}/build"
            }
            // "dependsOn": "cmake",
        }
    ]
}
Enter fullscreen mode Exit fullscreen mode

Run tasktasks

Do cmake first and then ninja clickhouse, ninja clickhouse will cost several hours.

Add settings.json file in dir .vscode to enable code reference.

{
    "clangd.path": "/usr/lib/llvm-18/bin/clangd",
    "clangd.checkUpdates": false,
    "clangd.arguments": [
        "--background-index",
        "--compile-commands-dir=build",
        "-j=12",
        "--query-driver=/usr/lib/llvm-18/bin/clang++",
        "--clang-tidy",
        "--clang-tidy-checks=performance-*,bugprone-*",
        "--all-scopes-completion",
        "--completion-style=detailed",
        "--header-insertion=iwyu",
        "--pch-storage=disk"
    ],
    "clangd.onConfigChanged": "restart",
    "lldb.commandCompletions": true,
    "lldb.dereferencePointers": true,
    "lldb.evaluateForHovers": true,
    "lldb.launch.expressions": "simple",
    "lldb.showDisassembly": "never",
    "lldb.verboseLogging": true,
    // cpp_tools Config
    "C_Cpp.autocomplete": "Disabled",
    "C_Cpp.formatting": "Disabled",
    "C_Cpp.errorSquiggles": "Disabled",
    "C_Cpp.intelliSenseEngine": "Disabled",
    "git.ignoreLimitWarning": true,
}
Enter fullscreen mode Exit fullscreen mode

If the word indexing appears at the bottom, it means the configuration is successful. If it fails, try restarting the window several times.

indexing

Debug

Start a stand-alone clickhouse-server instance and perform single-point debugging.
You need to confirm that LLDB is installed.
If the download speed is too slow, you can download it in website and install it manually.

install lldb manually

Add launch.json in dir .vscode:

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "Clickhouse Server",
            "type": "lldb",
            "request": "launch",
            "program": "${workspaceFolder}/build/programs/clickhouse",
            "args": [
                "server", "--config-file=${workspaceFolder}/programs/server/config.xml"
            ],
            "initCommands": [
                "process handle -p false -s false -n false SIGUSR1",
                "process handle -p false -s false -n false SIGUSR2"
            ],
            "preLaunchTask": "ninja clickhouse",
            // "stopAtEntry": false,
            // "osx": {
            // "MIMode": "lldb"
            // },
            "cwd": "${workspaceFolder}"
        }
    ]
}
Enter fullscreen mode Exit fullscreen mode

Launch clickhouse-server here, and you can mark some breakpoints to debug.

debug entrance

debug panel

Top comments (0)