debian配置distcc分布式编译

news/2024/10/18 8:20:29/

前言

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也有对应的方法来指定。


http://www.ppmy.cn/news/1440775.html

相关文章

Autosar MCAL-RH850P1HC Fls配置

文章目录 FlsFlsGeneralFlsAcLoadOnJobStartFlsBaseAddressFlsBlankCheckApiFlsCancelApiFlsCompareApiFlsCopySupportedFlsCriticalSectionProtectionFlsDevErrorDetectFlsDeviceNameFlsDriverIndexFlsFaciEccCheckFlsGetJobResultApiFlsGetStatusApiFlsLoopCountFlsReadImmed…

用flutter实现类似startActivityForResult和onActivityResult功能

今年实在是大卷元年呀,莫名其妙的flutter就开始在各大公司火了起来,然后就是全员学习flutter,公司可以不用,但是你必须得会。隔壁IOS同事瑟瑟发抖,咋啦?意思就是我走咯? 不管怎么说,…

AI预测体彩排列3第2套算法实战化测试第5弹2024年4月27日第5次测试

今天继续进行新算法的测试,今天是第5次测试。好了,废话不多说了,直接上图上结果。 2024年4月27日体彩排3预测结果 6码定位方案如下: 百位:6、2、1、7、8、9 十位:8、9、4、3、1、0 个位:3、7、8…

Nest 快速上手 —— (一)nest介绍与启动安装

参考资料:https://docs.nestjs.com/ 0.介绍 Nest (NestJS)是一个用于构建高效、可扩展的Node.js服务器端应用程序的框架。它使用渐进式JavaScript,构建并完全支持TypeScript(但仍然允许开发人员使用纯JavaScript编写代码),并结合了OOP(面向对…

【介绍下有那些常见的ssh功能】

🎥博主:程序员不想YY啊 💫CSDN优质创作者,CSDN实力新星,CSDN博客专家 🤗点赞🎈收藏⭐再看💫养成习惯 ✨希望本文对您有所裨益,如有不足之处,欢迎在评论区提出…

MySQL 按指定字段自定义列表排序

MySQL 按指定字段自定义列表排序 问题描述解决方案实际应用场景 问题描述 大家都知道, MySQL 中按某字段升序排列的 SQL 为 (以 id 为例, 下同): SELECT * FROM MyTable WHERE id IN (1, 7, 3, 5) ORDER BY id ASC 降序排列的 SQL 为: SELECT * FROM MyTable WHERE id IN (1…

【Pytorch】(十三)模型部署: TorchScript

文章目录 (十三)模型部署: TorchScriptPytorch动态图的优缺点TorchScriptPytorch模型转换为TorchScripttorch.jit.tracetorch.jit.scripttrace和script的区别总结trace 和script 混合使用保存和加载模型 (十三)模型部署: TorchScr…

常见的锁策略与死锁(详解)

文章目录 前言一、常见的锁策略1.乐观锁vs悲观锁2.重量级锁vs轻量级锁3.自旋锁vs挂起等待锁4.读写锁vs互斥锁5.公平锁vs非公平锁6.可重入锁vs不可重入锁可重入锁在哪释放锁 7.synchronized具体是采用了哪些锁策略呢?synchronized内部实现策略(内部原理)锁消除锁粗化 二、死锁1…