debian配置distcc分布式编译

前言

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

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

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

依赖

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

一、服务器

shell 复制代码
apt install distcc

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

1. 启动:

shell 复制代码
distccd --daemon --allow 0.0.0.0/0
#这样是允许所有IP都可以使用服务器进行编译。

2. 停止

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

shell 复制代码
pskill distccd

3. 配置

也可以在/etc/distcc/clients.allow中设置允许的主机。

还有其他配置。

二、客户机

shell 复制代码
apt install distcc

同理安装推荐的包。

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

1. 设置编译服务器

shell 复制代码
vim /etc/distcc/hosts

在里面填上编译器服务器地址:

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

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

2. 使用

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

shell 复制代码
cmake ../ -DCMAKE_CXX_COMPILER=distcc -DCMAKE_C_COMPILER=distcc

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

shell 复制代码
export DISTCC_HOSTS="localhost 192.168.1.104"
export DISTCC_VERBOSE=1
export DISTCC_LOG="/home/sixqaq/distcc.log"

3. 查看使用情况

需要安装包distccmon-gnome

用图形化界面查看:

shell 复制代码
$ distccmon-gnome

三、坑

distcc默认不会链接C++标准库。

在编译C++项目时就会报一堆链接失败的错误。

解决办法:

1. cmake

在CMakeLists.txt中添加:

shell 复制代码
link_libraries(stdc++)

2. distcc

shell 复制代码
$ distcc -lstdc++

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

相关推荐
C语言魔术师12 分钟前
【linux】linux进程概念(四)(环境变量)
linux·运维·服务器
松涛和鸣12 分钟前
DAY32 Linux Thread Programming
linux·运维·数据库·算法·list
Xyz996_40 分钟前
Ansible进行Nginx编译安装的详细步骤
运维·ansible
云和数据.ChenGuang1 小时前
自动化运维工程师之ansible启动rpcbind和nfs服务
运维·服务器·运维技术·数据库运维工程师·运维教程
yimengsama1 小时前
VMWare虚拟机如何连接U盘
linux·运维·服务器·网络·windows·经验分享·远程工作
松涛和鸣1 小时前
32、Linux线程编程
linux·运维·服务器·c语言·开发语言·windows
云和数据.ChenGuang1 小时前
AB压力测试运维工程师技术教程
运维·压力测试·运维工程师
少年白char1 小时前
【AI漫剧】开源自动化AI漫剧生成工具 - 从文字到影像:AI故事视频创作的全新可能
运维·人工智能·自动化
容智信息1 小时前
容智Report Agent智能体驱动财务自动化,从核算迈向价值创造
大数据·运维·人工智能·自然语言处理·自动化·政务
眠りたいです2 小时前
Docker:容器虚拟化技术基础-namespace,cgroups,资源管理与LXC
运维·docker·中间件·容器