博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
distcc源码研究五
阅读量:6152 次
发布时间:2019-06-21

本文共 813 字,大约阅读时间需要 2 分钟。

作者:朱金灿

来源:

 

        在《》我们分析到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. 

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

你可能感兴趣的文章
前端第七天
查看>>
图解SSH原理及两种登录方法
查看>>
【总结整理】JQuery基础学习---样式篇
查看>>
查询个人站点的文章、分类和标签查询
查看>>
基础知识:数字、字符串、列表 的类型及内置方法
查看>>
JSP的隐式对象
查看>>
JS图片跟着鼠标跑效果
查看>>
[SCOI2005][BZOJ 1084]最大子矩阵
查看>>
学习笔记之Data Visualization
查看>>
Leetcode 3. Longest Substring Without Repeating Characters
查看>>
416. Partition Equal Subset Sum
查看>>
app内部H5测试点总结
查看>>
[TC13761]Mutalisk
查看>>
while()
查看>>
常用限制input的方法
查看>>
IIS7下使用urlrewriter.dll配置
查看>>
并行程序设计学习心得1——并行计算机存储
查看>>
bulk
查看>>
C++ 迭代器运算
查看>>
【支持iOS11】UITableView左滑删除自定义 - 实现多选项并使用自定义图片
查看>>