• debian配置distcc分布式编译


    前言

    distcc 是一个用于在网络上的多台机器上分发 C、C++、Objective C 或 Objective C++ 代码构建的程序。 distcc 应始终生成与本地构建相同的结果,易于安装和使用,并且通常比本地编译快得多。

    distcc 不要求所有机器共享文件系统、同步时钟或安装相同的库或头文件。如果安装了交叉编译器,它们甚至可以具有不同的处理器或操作系统。

    它甚至不要求远程主机安装额外类库。

    依赖

    distcc只是编译器的“前端”,编译器需要使用gcc或者clang。

    一、服务器

    apt install distcc
    
    • 1

    最好把apt提示推荐的那几个包也装上。

    1. 启动:

    distccd --daemon --allow 0.0.0.0/0
    #这样是允许所有IP都可以使用服务器进行编译。
    
    • 1
    • 2

    2. 停止

    因为会起很多个进程,所以用pkill杀死全部。

    pskill distccd
    
    • 1

    3. 配置

    也可以在/etc/distcc/clients.allow中设置允许的主机。
    还有其他配置。

    二、客户机

    apt install distcc
    
    • 1

    同理安装推荐的包。

    客户机也可以运行一份distccd,不过没什么必要。

    1. 设置编译服务器

    vim /etc/distcc/hosts
    
    • 1

    在里面填上编译器服务器地址:
    在这里插入图片描述

    这个127.0.0.1不用加,只是方便测试。实际远程走不通时,distcc也会用本地编译器进行编译。

    我的客户机是有Qt环境的,远程机只装了编译器,实测可以成功编译。

    2. 使用

    直接用distcc代替gcc即可,例如cmake项目:

    cmake ../ -DCMAKE_CXX_COMPILER=distcc -DCMAKE_C_COMPILER=distcc
    
    • 1

    除了配置,还可以使用环境变量:

    export DISTCC_HOSTS="localhost 192.168.1.104"
    export DISTCC_VERBOSE=1
    export DISTCC_LOG="/home/sixqaq/distcc.log"
    
    • 1
    • 2
    • 3

    3. 查看使用情况

    需要安装包distccmon-gnome

    用图形化界面查看:

    $ distccmon-gnome
    
    • 1

    在这里插入图片描述

    三、坑

    distcc默认不会链接C++标准库。
    在编译C++项目时就会报一堆链接失败的错误。

    解决办法:

    1. cmake

    在CMakeLists.txt中添加:

    link_libraries(stdc++)
    
    • 1

    2. distcc

    $ distcc -lstdc++
    
    • 1

    make也有对应的方法来指定。

  • 相关阅读:
    分布式链路追踪- SkyWalking使用手册
    基于vue+node+mysql的视频校对系统
    【微机接口】中断的基本概念
    JAR防止反编译
    信息的定量描述
    Java刷题day22——牛客编程题
    React_创建一个项目
    怎么用多张图片制作动态图?
    C语言分析基础排序算法——交换排序
    (游戏:三个数的加法)编写程序,随机产生三个一位整数,并提示用户输入这三个整数的和,判断用户输入的和是否正确。
  • 原文地址:https://blog.csdn.net/qq_51470638/article/details/138169243