Linux内核编译实在是费时间的事,搞内核移植的时候总要编译,生命有一部分就浪费在等内核编译完成上,有心想买个HP的工作站,看了下Z840的价格,想想还是算了。distcc早就听说过,一直没有去试试,今天终于试了试,真是大赞啊!!下面说下如何配置,为了方便叙述,先定义几个称呼

  • 我直接工作的电脑称为L
  • 用来加速编译的电脑们称为A、B、C(它们也被称为compile farm)

安装

# L电脑
sudo apt install distcc distccmon-gnome distcc-pump # A/B/C电脑
sudo apt install distcc

配置

在L/A/B/C电脑上更改 /etc/default/distcc内容如下(注释已经删除)

STARTDISTCC="true"

# 下面的 /16表示前面的IP地址16位有效,即192..xx.xx的IP都是接受的
ALLOWEDNETS="127.0.0.1 192.168.0.0/16" LISTENER="" NICE="" JOBS="" ZEROCONF="true"

然后执行

sudo systemctl restart distcc

此时,若在任何一台电脑上执行 distcc --show-hosts,将会列出L/A/B/C电脑的IP或IPv6,格式为

<A-IP>:/
<C-IP>:/
<B-IP>:/
<L-IP>:/

其中3632是端口,这个是默认端口,一般不用改变,'/'后面限制的任务数,默认按4倍<CPU-threads>来计算的,如果这个时候执行后面将会提到的distcc-pump就会报没有host具有,cpp属性(这可以认为是distcc的一个bug,不过人家在man distcc里说明了,zeroconf不支持lzo和cpp属性,github上也明确表示不会合并patch,所以zeroconf我觉得也就是可以用来debug或初始化)

L电脑的打开 /etc/distcc/hosts,将刚才 distcc --show-hosts的输出写进去,并在每行后面加上,cpp,lzo,大约如下(把+zeroconf注释掉

<A-IP>:/,cpp,lzo
<C-IP>:/,cpp,lzo
<B-IP>:/,cpp,lzo
<L-IP>:/,cpp,lzo

使用hosts文件有几个好处(可能就是因为这些好处,以至于开发者都不去修正zeroconf的BUG)

  • 各电脑按照配置高低排序,把配置高的放前面,当任务少时先分配给配置高的机器
  • 各电脑的任务限制数可以手动更改(给A/B/C电脑一点剩余CPU)
  • L电脑自己需要执行预处理任务,应该把自己放到靠后的位置,并适当限制任务数,甚至不要放到列表中去
  • 手动增加,cpp,lzo属性,避开BUG

配置完成后,此时在L电脑上再次执行 distcc --show-hosts,输出就是/etc/distcc/hosts的文件内容

安装编译器

所有电脑需要安装编译器,并且放到相同的位置(我认为不太必要,只要都在PATH环境变量中就可以了吧),最好都是相同的版本。

编译内核

编译内核时,一般会先export ARCH 和 CROSS_COMPILE,这个不用改变,正常来即可,也可以放到命令行上,我比较喜欢export,最后编译执行命令是

distcc-pump make -j$(distcc -j) O=build-xxx CC="distcc ${CROSS_COMPILE}gcc"

这个时候可以打开 distccmon-gnome 看看壮观的景象,几分钟之后内核就编译好了!

后记

还有一个叫dmucs的东西,可以手动指定每台机器的power,然后自动执行负载均衡,并优先发给power强的机器,不过我配置的半天都不好使,而且我觉得配置起来也比较麻烦,就放弃了。有兴趣的同志可以研究下。

补记

在编译Linux内核某版本时,总是报远程无法编译过,但本地可以编译过,然后后面就会使用plain distcc mode,也就是本地预处理,远程编译的方式。这种方式显著降低编译速度,因为大量工作由本机来完成,而我本机的性能还不如编译服务器,一开始我也以为配置的问题,后来 man include_server告诉我,可以 export DISTCC_FALLBACK=0,然后远程编译的错误信息就会打出来,便于诊断,发现是下面的代码的问题

#define __gcc_header(x) #x
#define _gcc_header(x) __gcc_header(linux/compiler-gcc##x.h)
#define gcc_header(x) _gcc_header(x)
#include gcc_header(__GNUC__)

也就是说distcc预处理时无法知道要发送哪个头文件,并且没有检测出这个问题,导致远程编译时报 linux/compiler-gcc##x.h 未找到,这个问题work around的方法是,根据打印消息,把源代码临时改掉,不要因为这一个问题,导致编译速度显著下降。

另外 CC=distcc xxxx,如果xxxx不是绝对路径,那在远程编译服务器上也会按PATH去搜索,不过要注意PATH在远程是什么,如果是绝对路径就不需要搜索了,直接也使用绝对路径。

distcc加速内核编译的更多相关文章

  1. 【内核】linux2.6版本内核编译配置选项(二)

    目录 Linux2.6版本内核编译配置选项(一):http://infohacker.blog.51cto.com/6751239/1203633 Linux2.6版本内核编译配置选项(二):http ...

  2. 在阿里云中编译Linux4.5.0内核 - Ubuntu内核编译教程

    实验环境:Ubnuntu 64位(推荐使用14.04)+Xshell 阿里云现在提供的云服务器很好用的,用来编译内核性能也不错.本文介绍最基本的内核编译方法,为了方便,所有操作均在root用户下进行. ...

  3. zju(3)内核编译与运行

    1.实验目的 学习和掌握Linux配置和编译的基本步骤. 二.实验内容 1. 对Linux内核及用户程序进行配置: 2. 编译生成内核映像文件: 3. 把编译的映像文件烧写到FLASH中,查看运行结果 ...

  4. linux内核编译,配置本机驱动

    1.前言  编译linux内核失败的原因很多时候就是驱动选错,适合自己本机的驱动没编译进去.面对特殊平台(或者有些洁癖者,我就是^_^),要编译精简内核,只要本机驱动,其他都不需要.面对内核里面这么多 ...

  5. linux内核编译相关

    参考:http://www.arm.linux.org.uk/docs/kerncomp.php 一. 内核编译1) linux 2.4make clean/make mrpropermake dep ...

  6. 运行在TQ2440开发板上以及X86平台上的linux内核编译

    一.运行在TQ2440开发板上的linux内核编译 1.获取源码并解压 直接使用天嵌移植好的“linux-2.6.30.4_20100531.tar.bz2”源码包. 解压(天嵌默认解压到/opt/E ...

  7. 【转】内核编译时, 到底用make clean, make mrproper还是make distclean(转载)

    原文网址:http://dongyulong.blog.51cto.com/1451604/449470 内核编译时, 到底用make clean, make mrproper还是make distc ...

  8. linux 驱动模块 内核编译环境

    目录(?)[+] Linux设备驱动Hello World程序介绍 如何编写一个简单的linux内核模块和设备驱动程序.我将学习到如何在内核模式下以三种不同的方式来打印hello world,这三种方 ...

  9. linux内核编译环境配置

    linux内核编译环境配置 如果不是编译内核,只需要安装与内核相匹配的kernel-devel开发包即可.即是/lib/modules/`uname -r`/build -> /usr/src/ ...

随机推荐

  1. Django REST framework(官方说明文档翻译)(1快速开始 )

    http://www.django-rest-framework.org/tutorial/quickstart/ 第一部分:快速开始 我们将创建一个简单的api接口,用来给admin用户查看及编辑系 ...

  2. 小白入门篇:flex布局

    --前言 因为这个星期写一个小的项目用到flex布局和grid布局,虽然这两种布局都是兼容性都有问题,但是别急,我觉的以后肯定是会发展并且流行起来的,毕竟google大法好,而且这两个布局真的比一般的 ...

  3. elasticsearch REST api

    elasticsearch REST api========================================命令模式:<REST Verb> /<Index>/ ...

  4. Python爬取中国天气网

    Python爬取中国天气网 基于requests库制作的爬虫. 使用方法:打开终端输入 “python3 weather.py 北京(或你所在的城市)" 程序正常运行需要在同文件夹下加入一个 ...

  5. [CP1804]最短路

    题目大意: 一个$n(n\le10^5)$个点的图,给定一个常数$c$,每对点$i,j$之间有权值为$(i\oplus j)\times c$的边.另有$m(m\le5\times10^5)$条指定权 ...

  6. Stage3D 中的PerspectiveMatrix3D

    PerspectiveMatrix3D继承自Matrix3D.表示投影矩阵的功能类. 公式:用4X4矩阵向z=d的平面投影 public function perspectiveFieldOfView ...

  7. 前端JavaScript实现跨域的方式(转)

    这里说的js跨域是指通过js在不同的域之间进行数据传输或通信,比如用ajax向一个不同的域请求数据,或者通过js获取页面中不同域的框架中(iframe)的数据.只要协议.域名.端口有任何一个不同,都被 ...

  8. C#如何把日期转成YYYYMMDDHHMMSSFFF的精确到毫秒的格式?

    C#如何把YYYY-MM-DD HH:MM:SS格式的日期转成YYYYMMDDHHMMSS的格式? 方法一:string   src= (new DataTime()).ToString(); str ...

  9. .net的远程调用

    .Net远程调用(转自:http://www.cnblogs.com/omilan/articles/3191378.html) 看到了这.net远程调用的讲解,觉得不错,拿来分享!! .Net对于远 ...

  10. iframe.contentWindow 属性:关于contentWindow和contentDocument区分

    定义和用法 contentDocument 属性能够以 HTML 对象来返回 iframe 中的文档,可以通过所有标准的 DOM 方法来处理被返回的对象. 语法:frameObject.content ...