distcc源码研究五

作者:朱金灿

来源:http://blog.csdn.net/clever101

 

        在《distcc源码研究四》我们分析到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.  使用distcc进行分布式编译

 

2.  分布式编译


转载于:https://www.cnblogs.com/lanzhi/archive/2012/02/06/6470885.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值