文档章节

ThoughtWorks Go基本概念

donhui
 donhui
发布于 2014/09/21 23:01
字数 662
阅读 1603
收藏 7

写在前面:当前最流行的持续集成工具非jenkins莫属,已使用jenkins一年有余,想尝试下别的CI工具,如ThoughtWorks Go,且在尝试时做主要记录并分享,这是首先介绍下基本概念......

ThoughtWorks Go 是 ThoughtWorks 公司的一款持续集成和发布的系统。
它用一个创新的方法来管理构建、测试和发布过程。
其前身为CruiseControl(ThoughtWorks开发的第一个CI服务器)。

Go是以“部署流水线”为核心的,下面是一个来自Go官网的流水线(pipeline)案例:

上图涉及到的基本概念有:pipeline(流水线)、stage(阶段)、job(作业)

表示的是一个产品从代码提交(check in)到UAT测试的流水线(pipeline)。

  • 版本控制系统(Version Control System,即VCS),如svn、git、hg等中的代码修改后可以通过post commit hook触发这个流水线。

  • 一个pipeline包含一个或多个stage,stage是串行的。
    这个流水线(pipeline)有三个阶段(stage):编译+单元测试阶段(compile+unit test stage)、功能测试阶段(functional test stage)、用户验收测试阶段(UAT stage)。

  • 一个stage包含一个或多个job,job是并行的。
    其中编译+单元测试阶段(compie+unit test stage)包含单元测试作业(unit test job)和代码测试覆盖率检查作业(emma job)。

  • 此外,pipeline可以分组,可以把多个pipeline放到一个pipeline group中。

对红色StageJob做下翻译:

阶段(Stage):

  • 阶段是连续运行的

  • 每个阶段可以被前一个阶段完全运行成功后自动触发

  • 也可以手动触发

作业(Job)

  • 作业可以在阶段中并发运行

  • 如果一个作业失败了,这个阶段的状态就是失败的

  • 每个作业计划运行一个或多个目标(target),如ant、nant等等

  • 如果有多个Go Agent,一个阶段的作业可以并行

Go的架构设计:

Go使用了Server-Agent模式,Server用来展示和配置pipeline的DashBoard,并存放构建出来的Artifacts(存档文件,比如一个war包); Agent则用来执行真正的构建操作,一个Server可以和多个Agent建立连接,Agent支持多个主流的操作系统。

这个和jenkins的Master-slave架构模式有些类似。

参考:http://www.thoughtworks.com/products/docs/go/current/help/conceptsingo.html


© 著作权归作者所有

donhui

donhui

粉丝 51
博文 85
码字总数 39518
作品 0
杭州
程序员
私信 提问
加载中

评论(1)

乐儿
乐儿
赞一个42
2019 技术雷达十年峰会

活动详情 在技术快速变革的今天,技术在企业发展和转型的过程中扮演着越来越重要的角色。而大多数企业在转型过程中都不可避免面临一个困境:一方面需要大胆采用先进的技术,为企业的“数字化...

TWer
02/21
0
0
深圳活动 | 8月20日Office Warming Party

ThoughtWorks深圳办公室刚迁新址,我们将于8月20日(周六)举办Office Warming Party: 想知道《重构》作者Martin Fowler加入的是一家什么样的公司?在这里,你将真实触摸ThoughtWorks企业文...

jobthoughtworks
2016/08/12
27
0
ThoughtWorks:这是一个新的时代

作为一家服务于全球不同类型客户的IT专业公司,ThoughtWorks一直致力于用卓越的技术解决不同的问题。ThoughtWorks技术雷达是ThoughtWorks服务于各个行业客户的技术准绳,中科软总裁曾做出对此...

玄学酱
2018/05/25
0
0
Moco框架 一个中国技术极客的开源之梦

  【IT168评论】郑晔,本次受访的嘉宾,自称技术极客,对软件开发有着浓厚的兴趣,个人一直希望将写代码成为终身的职业。除了技术气息浓郁之外,郑晔也颇有表达欲望,面对记者的提问滔滔不...

it168网站
2013/08/13
0
0
ThoughtWorks 技术雷达十周年峰会在深举行

3月15日,ThoughtWorks 技术雷达十周年峰会在深圳中洲万豪酒店举行。ThoughtWorks 全球技术委员会成员 Martin Fowler、知名作者 Neal Ford、ThoughtWorks 全球首席技术官 Rebecca Parsons 等...

大大大大风车
03/18
0
0

没有更多内容

加载失败,请刷新页面

加载更多

axios 使用步骤很简单,首先在前端项目中,引入 axios:

  前端网络访问,主流方案就是 Ajax,Vue 也不例外,在 Vue2.0 之前,网络访问较多的采用 vue-resources,Vue2.0 之后,官方不再建议使用 vue-resources ,这个项目本身也停止维护,目前建...

SEOwhywhy
30分钟前
3
0
c++ 创建对象的三种方法

c++有三种方法创建对象 结合代码来看 1 #include <iostream> 2 using namespace std; 3 class Test { 4 5 private: 6 public: 7 add() 8 { 9 ......

天王盖地虎626
44分钟前
1
0
ant 中的fileset include等拷贝

拷贝一个目录到指定目录下 例:<copy todir="${basedir}/new"> <fileset dir="${basedir}/old"> <include name="appgen" /> <include name="appgen/" /> <include name=appgen/**" /> <incl......

shzwork
50分钟前
2
0
react-jianshu项目的创建

创建项目 1、github上创建仓库react-jianshu 2、将项目克隆到本地git clone git@github.com:startjcu/react-jianshu.git 3、在当前目录(项目目录的上级目录)下执行create-react-app react-...

星闪海洋
59分钟前
2
0
OSChina 周二乱弹 —— 小哥哥,你可以教我写代码吗

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @nnnm: 生活大爆炸,结束了,这部陪伴了漫长时间的情景喜剧,最终是以诺贝尔奖和大团圆收尾的。虽然,不算精彩,但也是温馨。而少年谢尔顿的...

小小编辑
今天
858
13

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部