跳到主要内容
跳到主要内容

在 Linux 上为 s390x(zLinux)进行构建

ClickHouse 对 s390x 提供实验性支持。

为 s390x 构建 ClickHouse

与其他平台一样,s390x 会将 OpenSSL 构建为静态库。如果你希望使用动态链接的 OpenSSL 进行构建,则需要向 CMake 传递 -DENABLE_OPENSSL_DYNAMIC=1

这些说明假定宿主机为 Linux x86_64/ARM,并且已经按照构建说明安装了本机构建所需的全部工具。同时假定宿主机运行的是 Ubuntu 22.04,不过以下说明同样适用于 Ubuntu 20.04。

除了安装用于本机构建的工具外,还需要安装以下额外软件包:

apt-get mold
rustup target add s390x-unknown-linux-gnu

构建 s390x 版本:

cmake -DCMAKE_TOOLCHAIN_FILE=cmake/linux/toolchain-s390x.cmake ..
ninja

运行

要进行仿真,你需要适用于 s390x 的 QEMU user static 静态二进制文件。在 Ubuntu 上可以通过以下命令安装:

apt-get install binfmt-support binutils-s390x-linux-gnu qemu-user-static

构建完成后,例如可以通过以下命令运行该二进制文件:

qemu-s390x-static -L /usr/s390x-linux-gnu ./programs/clickhouse local --query "Select 2"
2

调试

安装 LLDB:

apt-get install lldb-21

要调试 s390x 可执行文件,请使用 QEMU 以调试模式运行 ClickHouse:

qemu-s390x-static -g 31338 -L /usr/s390x-linux-gnu ./clickhouse

在另一个 shell 中运行 LLDB 并进行附加操作,将 <Clickhouse Parent Directory><build directory> 替换为与您环境相对应的值。

lldb-15
(lldb) target create ./clickhouse
Current executable set to '/<Clickhouse Parent Directory>/ClickHouse/<build directory>/programs/clickhouse' (s390x).
(lldb) settings set target.source-map <build directory> /<Clickhouse Parent Directory>/ClickHouse
(lldb) gdb-remote 31338
Process 1 stopped
* thread #1, stop reason = signal SIGTRAP
    frame #0: 0x0000004020e74cd0
->  0x4020e74cd0: lgr    %r2, %r15
    0x4020e74cd4: aghi   %r15, -160
    0x4020e74cd8: xc     0(8,%r15), 0(%r15)
    0x4020e74cde: brasl  %r14, 275429939040
(lldb) b main
Breakpoint 1: 9 locations.
(lldb) c
Process 1 resuming
Process 1 stopped
* thread #1, stop reason = breakpoint 1.1
    frame #0: 0x0000004005cd9fc0 clickhouse`main(argc_=1, argv_=0x0000004020e594a8) at main.cpp:450:17
   447  #if !defined(FUZZING_MODE)
   448  int main(int argc_, char ** argv_)
   449  {
-> 450      inside_main = true;
   451      SCOPE_EXIT({ inside_main = false; });
   452
   453      /// PHDR cache is required for query profiler to work reliably

Visual Studio Code 集成

  • 进行可视化调试需要安装 CodeLLDB 扩展。
  • 如果使用 CMake Variants,可以安装 Command Variable 扩展来辅助配置动态启动。
  • 请确保将后端设置为你的 LLVM 安装路径,例如:"lldb.library": "/usr/lib/x86_64-linux-gnu/liblldb-21.so"
  • 在启动之前,请确保以调试模式运行 ClickHouse 可执行文件。(也可以创建一个 preLaunchTask 来自动完成此操作)

示例配置

cmake-variants.yaml

buildType:
  default: relwithdebinfo
  choices:
    debug:
      short: Debug
      long: 输出调试信息
      buildType: Debug
    release:
      short: Release
      long: 优化生成代码
      buildType: Release
    relwithdebinfo:
      short: RelWithDebInfo
      long: 发布版本(含调试信息)
      buildType: RelWithDebInfo
    tsan:
      short: MinSizeRel
      long: 最小体积发布版本
      buildType: MinSizeRel

toolchain:
  default: default
  description: 选择工具链
  choices:
    default:
      short: x86_64
      long: x86_64
    s390x:
      short: s390x
      long: s390x
      settings:
        CMAKE_TOOLCHAIN_FILE: cmake/linux/toolchain-s390x.cmake

launch.json

{
    "version": "0.2.0",
    "configurations": [
        {
            "type": "lldb",
            "request": "custom",
            "name": "(lldb) 使用 qemu 启动 s390x",
            "targetCreateCommands": ["target create ${command:cmake.launchTargetPath}"],
            "processCreateCommands": ["gdb-remote 2159"],
            "preLaunchTask": "运行 ClickHouse"
        }
    ]
}

settings.json

这也会将不同的构建产物放在 build 文件夹下的不同子文件夹中。

{
    "cmake.buildDirectory": "${workspaceFolder}/build/${buildKitVendor}-${buildKitVersion}-${variant:toolchain}-${variant:buildType}",
    "lldb.library": "/usr/lib/x86_64-linux-gnu/liblldb-21.so"
}

run-debug.sh

#! /bin/sh
echo '正在启动调试器会话'
cd $1
qemu-s390x-static -g 2159 -L /usr/s390x-linux-gnu $2 $3 $4

tasks.json

定义了一个任务,用于在与二进制文件同级的 tmp 目录下,以 server 模式运行已编译的可执行文件,并从 programs/server/config.xml 加载配置。

{
    "version": "2.0.0",
    "tasks": [
        {
            "label": "运行 ClickHouse",
            "type": "shell",
            "isBackground": true,
            "command": "${workspaceFolder}/.vscode/run-debug.sh",
            "args": [
                "${command:cmake.launchTargetDirectory}/tmp",
                "${command:cmake.launchTargetPath}",
                "server",
                "--config-file=${workspaceFolder}/programs/server/config.xml"
            ],
            "problemMatcher": [
                {
                    "pattern": [
                        {
                            "regexp": ".",
                            "file": 1,
                            "location": 2,
                            "message": 3
                        }
                    ],
                    "background": {
                        "activeOnStart": true,
                        "beginsPattern": "^启动调试器会话",
                        "endsPattern": ".*"
                    }
                }
            ]
        }
    ]
}