debian配置distcc分布式编译

ops/2024/9/25 21:28:07/

前言

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/ops/13773.html

相关文章

Linux--系统烧写

前面几篇文章,已经搞定了Linux移植三巨头:uboot、kernel(包含dtb)和rootfs,除了uboot是烧写在SD中的,其它的都是在ubuntu虚拟机的nfs服务器中,运行时必须通过网络将这些文件加载到开发板的内存中运行。 本篇就来研究&a…

带头双向循环链表的基本操作(c语言实现)

带头双向循环链表 带头双向循环链表是一种结合了双向链表和循环链表特性的数据结构。其主要特点如下: 双向性:链表中的每个节点都有两个指针,一个指向下一个节点(next),另一个指向前一个节点(p…

C语言操作符和关键字

文章目录 操作符单目操作符sizeof(类型)强制类型转换 关系操作符、逻辑操作符、条件操作符逗号表达式 常见关键字typedefstaticstatic修饰局部变量static修饰全局变量static修饰函数 register寄存器关键词define定义常量和宏 操作符 单目操作符 C语言中…

前缀和 求数列的子序列的K倍区间

(直接截图比复制文字要好多了) 不会做的时候我去看了之前做的关于这道题目的笔记, (Ak 1)% k 1 (Ak 1 Ak)% k 1 只要发现了同余数的情况就说明有一个区间满足了题目的要求。 这个方法的精妙之处就在于前缀和包括了…

背靠TON公链的Notcoin游戏项目,能否杀出GameFi的红海?

4月15日消息,Telegram生态中的游戏及Meme项目Notcoin,最近在X平台公布了令市场瞩目的代币经济学方案。据悉,NOT的总供应量高达1027亿枚,其中78%将分配给矿工和Voucher持有者,余下的22%预留给未来新用户、交易者及各类上…

【Linux驱动层】iTOP-RK3568学习之路(五):并发与竞争

本人在听讯为的课时,哪怕是照抄,编译后,这里的代码执行不了,只能做笔记了。 一、原子操作 ​ 借用原子是"化学反应中最小的微粒“这个概念,用原子来表述—个操作是不可以被打断,拆分的操作。简单&…

迪拜Token2049展会圆满落幕,MVP成唯一MEMECOIN项目,闪耀全场!

近日,据多家媒体报道,于全球财富聚集地迪拜举行的全球性大型区块链会议TOKEN2049圆满落幕。来自全球的5000多家公司和100多个国家10000名参与者共同参会,讨论未来30年至50年关于区块链行业的宏大未来。 新晋MEMECOIN项目MAGA VP(…

使用 Flask-WTF 防止跨站请求攻击(CSRF):一份全面指南

在构建 Web 应用时,防止跨站请求攻击(CSRF)是一项至关重要的安全措施。CSRF 攻击允许恶意网站执行未经授权的操作,如用户身份验证或数据篡改。幸运的是,Flask-WTF 库为我们提供了强大的 CSRF 保护功能。在本篇博客中&a…