作者:朱金灿
来源:
在《》我们分析到distcc将编译服务器取出并进行锁定。我们主要分析的是dcc_build_somewhere函数。dcc_build_somewher比较复杂。在进一步分析dcc_build_somewhere函数之前,我感到我们有必要对distcc的工作原理作一个简单的了解。distcc的工作原理简单来说是这样的:distcc 将预处理代码发送给网络中的其他指定机器。distccd 守护进程确保编译在远程机器上发生,因此在编译时验证 distccd 守护进程正在远程机器上运行。因此dcc_build_somewher函数大致是分为两步的:一步叫远程编译,其实就是将预处理代码发送给网络中的其他指定机器,另一步就是本地编译。因此我们得到以下一些猜测:所谓的远程编译实际上是本地机器将预处理代码发到网络中的其他指定机器,实际上编译进程是发生在其它机器上的,这里涉及到本地机器和其它机器的通讯过程,远程编译完成后必然要把编译结果传给本地机器,本地机器也必须等待远程编译完成之后才能进行本地编译。由此你也看出DistCC和IncrediBuild的差别在与DistCC不使用仲裁者, 直接由客户端对其他客户端发起编译请求. 所以每个客户端都需要知道其他客户端的位置, 并且当多个客户发起编译请求时不易做平衡处理。
在接下来的日子里我们将研究下面问题:
1. distcc客户端将预处理代码传给服务端,那么在程序中预处理代码到底是什么?
2. distcc客户端是如何服务器端通讯的?
3. distcc客户端是如何等待远程编译完成的?
4. 远程编译完成后将编译结果传给客户端,在程序中编译结果具体指什么?
5. 本地编译的具体过程又是怎样的?
参考文献:
1.
2.