上一篇:在FASTBuild中使用Caching

在FASTBuild中使用分布式(distribution)编译需要注意以下四个环节。

一、编译器设置

  某些编译过程与分布式相矛盾,如果一个对象不能被安全的分发出去,那它将自动在本地被编译,一个编译过程可以安全的混合可分发对象与不可分发对象。

  对于GCC/SNC/Clang编译器,没有任何限制。

  对于MSVC编译器:

    /ZW 选项不能使用

    预编译头文件不能被分发,他们是因机器而异的。(使用了PCH的对象可以被分发)

    /clr 选项不能使用,因为微软编译器的预处理器有bug。

 二、编译器同步

  FASTBuild会把编译器(Compiler)同步到远端机器的一个隔离的环境中,这避免了远端机器也需要安装工具链,并且能保证编译器的一致性。为了实现这些,FASTBuild需要知道通过网络要同步哪些文件。这需要通过Compiler函数来实现。下面以一个实测可用的编译器配置,以 VS 2015 amd 64位编译器为例:

.VSBasePath = 'C:\Program Files (x86)\Microsoft Visual Studio 14.0'

Compiler('MSVC2015')              // (optional) Alias
{
.Executable = '$VSBasePath$\VC\bin\amd64\cl.exe'
.ExtraFiles = { '$VSBasePath$\VC\bin\amd64\1033\clui.dll',
'$VSBasePath$\VC\bin\amd64\c1.dll',
'$VSBasePath$\VC\bin\amd64\c2.dll',
'$VSBasePath$\VC\bin\amd64\c1xx.dll',
'$VSBasePath$\VC\bin\amd64\mspdb140.dll',
'$VSBasePath$\VC\bin\amd64\msobj140.dll',
'$VSBasePath$\VC\bin\amd64\mspdbcore.dll',
'$VSBasePath$\VC\bin\amd64\mspdbsrv.exe'}
}

三、工作者目录

  工作者(Worker)就是除了主机之外,通过网络参与到分布式编译过程中的其他机器,他们的职责就是在空闲的时候,提供若干个(可设置)CPU内核出来,供主机编译使用。工作者(Worker)需要通过一个商定的位置被找到,这个商定的位置是一个主机(host)和工作者(Worker)都能找到的网络路径。这个路径要通过环境变量 FASTBUILD_BROKERAGE_PATH 来设置。工作者通过在这个位置写一个标记来示意自己可用。客户机通过检查这个位置来寻找可用的工作者。这里的重点是这个FASTBUILD_BROKERAGE_PATH 指定的必须是一个共享网络路径,而且能被所有参与分布式编译的机器自由地读写

  下面是一个简单的启动FASTBuildWorker的bat脚本(start_fbuild_worker.bat),如果发现该进程已存在,则不做任何操作。正常模式启动,启动后在桌面右下角会有图标显示。

echo off & color 0A
rem 在这里设置的环境变量只在bat脚本内有效
set FASTBUILD_BROKERAGE_PATH=\\192.168.22.31\.fastbuild.brokerage
tasklist | find /i "FBuildWorker.exe.copy" || start /min "" FBuildWorker.exe -cpus=2 -mode=idle

  下面是一个简单的启动FASTBuildWorker的vbs脚本(start_fbuild_worker.vbs),如果发现该进程已存在,则不做任何操作。控制台模式启动(-console),并且隐藏了窗口,启动后只在任务管理器中才能被看到。具体用途自己体会。(在实际应用中发现,这个脚本第一次运行不会生效,大概是刚刚设置的环境变量在脚本中没有生效,不过Worker进程关闭之后,再次运行就会生效了)

set bag=getobject("winmgmts:\\.\root\cimv2")
set pipe=bag.execquery("select * from win32_process where name='FBuildWorker.exe'")
For Each id In pipe
wscript.quit
Next
wscript.CreateObject("Wscript.Shell").Environment("user").Item("FASTBUILD_BROKERAGE_PATH")="\\192.168.22.31\.fastbuild.brokerage"
wscript.CreateObject("Wscript.Shell").Run "FBuildWorker.exe -cpus=2 -mode=idle -console",

  Worker启动后,会在刚才设置的那个网络路径中写一个标记,表示自己随时可以被调用,如下图:

  

  大家不要担心这个Worker进程会占用太多资源,当你的CPU处于繁忙的状态,他会自动地把自己的标记取消,使自己不可被调用。换句话说,Worker(s)只会在自己有余力的时候才会帮助他人工作。

  四、激活分布式编译

  在上述步骤都顺利完成之后,便可以开始分布式编译了。执行fbuild.exe的时候,只需要加上 -dist 或者 -distverbose 参数,就可以调用远端的Worker为自己工作。

  下面是一个简单的启动fbuild的bat脚本

echo off & color 0A
rem 在这里设置额环境变量只在bat脚本内有效
set FASTBUILD_BROKERAGE_PATH=\\192.168.22.31\.fastbuild.brokerage
call start_fbuild_worker.bat
fbuild.exe -cache -distverbose
pause

  这里调用了start_fbuild_worker.bat脚本,其实使用分布式编译不一定非要在本机打开Worker进程,但是本着互惠互利的原则,在使用别人的CPU核心的时候,最好自己也开启Worker进程。

  以上便是我学习使用FASTBuild的总结,不可否认FASTBuild作为一个免费开源的分布式编译工具,性能相当出色,之前我们的C++项目使用VS完全编译一次需要花费40min,在使用了FASTBuild之后,开启Caching和Distribution,可以在5min内完全编译一次,效率提升了近90%。感谢FASTBuild的开发人员,让我和同事们在工作的时候心情舒畅了很多。

上一篇:在FASTBuild中使用Caching

 

在FASTBuild中使用Distribution的更多相关文章

  1. 在FASTBuild中使用Caching

    上一篇:初识FASTBuild 在FASTBuild中使用缓存只需要注意三个环节: 一.设置编译选项 对于GCC\SNC\Clang编译器,没有特殊的要求 对于MSVC编译器,必须设置/Z7调试模式. ...

  2. 向安装包中添加设备 UDID. 蒲公英内测

    向安装包中添加设备 UDID 前言 注:本文适用于只有苹果个人开发者账号.公司开发者账号.或教育开发者账号的 iOS 开发者. 对于没有企业开发者账号(299$)的开发者来说,要想使用蒲公英将自己的应 ...

  3. 初识FASTBuild 一个大幅提升C/C++项目编译速度的分布式编译工具

    FASTBuild 是一款高性能.开源的构建系统,支持高度可扩展的编译,缓存和网络分发. 以上是FASTBuild官网对其产品的一句话介绍. FASTBuild 的开源地址:https://githu ...

  4. iOS 关于 Missing iOS Distribution signing identity for.... 等 打包 校验 出现的事故 处理经验

    着实郁闷了一阵子,不知道为什么 证书和配置文件都没有问题 在Archieve后  validate 提示:"Missing iOS Distribution signing identity ...

  5. C++中的随机数

    事情的开始是这样的,在大二的时候,写了几种排序算法,为了测试,就要为数组(或者容器)赋予一些随机初值,自然就用到了C/C++中的随机函数. 当时为了调用简单,将随机数赋值的过程写到了一个单独的函数里, ...

  6. IOS在自己网站发布APP(企业版$299上线流程)

    最近刚上线一个企业内部应用,前期准备账号和后期上线过程发现网络上的资源不是非常全面,在这里写给大家分享一下我的发布过程 首先是企业账号的申请我们企业账号前前后后一共花了16天时间,由于公司各方面都非常 ...

  7. linux xwiki搭建过程

    安装mysql数据库,并创建xwiki数据库及用户 mysql> create database xwiki; Query OK, 1 row affected (0.00 sec) mysql ...

  8. 事务复制中的snapshot

        Snapshot agent读取article的信息,将article的内容和脚本放置到snapshot文件夹中: 接下来distribution agent会读取这些快照文件,传输到订阅,完 ...

  9. iOS中远程推送实现—在Apple的生产环境上测试Push Notifications功能

    1.在“Provisioning Profiles”中点击“Add”按钮. 2.在“What type of provisioning profile do you need?”页面中选择“Distr ...

随机推荐

  1. centos7安装tengine强制使用HTTPS访问

    操作系统:centos7.2 x64tengine:Tengine/2.2.0主机IP: 10.0.0.12 一.安装tengine 1.1 下载源码安装包 1.1.1 源码包pcre-8.40   ...

  2. HTML布局相关的CSS样式属性

    # 转载请留言联系 注意,样式属性是写进CSS里面的. 布局常用样式属性: width 设置元素(标签)的宽度,如:width:100px; height 设置元素(标签)的高度,如:height:2 ...

  3. python中的闭包与装饰器

    #原创,转载请留言联系 装饰器的本质就是闭包,所以想知道装饰器是什么,首先要理解一下什么是闭包. 闭包 1. 外部函数返回内部函数的引用.2. 内部函数使用外部函数的变量或者参数. def outer ...

  4. MYSQL通过索引优化数据库的查询

    #转载请联系 索引是什么? 索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的位置信息. 更通俗的说,数据库索引好比是一本书前面的目录,能加快数据 ...

  5. Qt笔记——QFile,QDataStream,QTextStream

    QFile #ifndef WIDGET_H #define WIDGET_H #include <QWidget> namespace Ui { class Widget; } clas ...

  6. HDU 2547 无剑无我(数学)

    #include<cstdio> #include<iostream> #include<cmath> int main() { double a,b,c,d,m; ...

  7. small test on 5.30 night T1

    数学题使劲推就对了. 让我们设  g(x) = ∑ C(i,x) * b^i ,然后后面验算了一张纸QWQ,懒得再打一遍了,回家我就把这张演算纸补上QWQ,先上代码. #include<cstd ...

  8. HDU 6017 Girls Love 233(多态继承DP)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=6017 [题目大意] 给出一个只包含2和3的串,你可以花费两个智力值交换相邻的两个字符 问在智力值不 ...

  9. IO流--字符流缓冲技术

    缓冲技术是为了提高数据的读写效率而提出的. (1)字符流的缓冲读 在字符流的缓冲技术中提供了一个newLine()方法,这个方法是跨平台的 在读数据的时候采用读完直接刷新的方式可以保证断电后数据不会丢 ...

  10. linux-统计文件中相同行的数量

    cat sorttest | sort | uniq -c sorttest文件内容如下