前言
distcc 是一个用于在网络上的多台机器上分发 C、C++、Objective C 或 Objective C++ 代码构建的程序。 distcc 应始终生成与本地构建相同的结果,易于安装和使用,并且通常比本地编译快得多。
distcc 不要求所有机器共享文件系统、同步时钟或安装相同的库或头文件。如果安装了交叉编译器,它们甚至可以具有不同的处理器或操作系统。
它甚至不要求远程主机安装额外类库。
依赖
distcc只是编译器的“前端”,编译器需要使用gcc或者clang。
一、服务器
apt install distcc
最好把apt提示推荐的那几个包也装上。
1. 启动:
distccd --daemon --allow 0.0.0.0/0
#这样是允许所有IP都可以使用服务器进行编译。
2. 停止
因为会起很多个进程,所以用pkill
杀死全部。
pskill distccd
3. 配置
也可以在/etc/distcc/clients.allow
中设置允许的主机。
还有其他配置。
二、客户机
apt install distcc
同理安装推荐的包。
客户机也可以运行一份distccd
,不过没什么必要。
1. 设置编译服务器
vim /etc/distcc/hosts
在里面填上编译器服务器地址:
这个127.0.0.1不用加,只是方便测试。实际远程走不通时,distcc也会用本地编译器进行编译。
我的客户机是有Qt环境的,远程机只装了编译器,实测可以成功编译。
2. 使用
直接用distcc
代替gcc
即可,例如cmake项目:
cmake ../ -DCMAKE_CXX_COMPILER=distcc -DCMAKE_C_COMPILER=distcc
除了配置,还可以使用环境变量:
export DISTCC_HOSTS="localhost 192.168.1.104"
export DISTCC_VERBOSE=1
export DISTCC_LOG="/home/sixqaq/distcc.log"
3. 查看使用情况
需要安装包distccmon-gnome
。
用图形化界面查看:
$ distccmon-gnome
三、坑
distcc默认不会链接C++标准库。
在编译C++项目时就会报一堆链接失败的错误。
解决办法:
1. cmake
在CMakeLists.txt中添加:
link_libraries(stdc++)
2. distcc
$ distcc -lstdc++
make也有对应的方法来指定。