ThoughtWorks Go基本概念

写在前面:当前最流行的持续集成工具非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

时间: 2024-10-09 07:37:21

ThoughtWorks Go基本概念的相关文章

thoughtworks笔试整理

笔试了,时间1个半小时.没想到居然有7/10是开放性问题.大意例如以下:1.为什么选择增加ThoughtWorks.200字以内,不能用"interesting"."challenge"等词汇amazing place, I found that almost all TWers love this company and get a lot of fun from their work, very few companies can make this. I th

Microservice 概念

一天我司招财猫姐(HR 大人)问我,你给我解释一下 Microservice 是什么吧.故成此文.一切都是从一个创业公司开始的. 故事 最近的创业潮非常火爆,我禁不住诱惑也掺和了进去,创建了一家公司.为了表达我的抱负,取千秋万代,一统江湖之意.我给公司定下了一个非常响亮的名字叫做——一统. 从集中到分权 虽说叫做一统但是凡是都要从头开始,公司成立之初有五个成员:罗密欧,朱丽叶,维克多,布拉伯还有老大——我.我们五个人都是工程师出身,自身具备了非常优秀的学习能力,各个都是从业务到代码的好手,五个人

ThoughtWorks 2017技术雷达

前言: ThoughtWorks人酷爱技术.我们对技术进行构建.研究. 测试.开源.记述,并始终致力于对其进行改进-以求造福 大众.我们的使命是支持卓越软件并掀起IT革命.我们创建 并分享ThoughtWorks技术雷达就是为了支持这一使命.由 ThoughtWorks中一群资深技术领导组成的ThoughtWorks 技术顾问委员会(TAB)创建了该雷达.他们定期开会讨论 Thoughtworks的全球技术战略以及对行业有重大影响的 技术趋势. 这个雷达以独特的形式记录技术顾问委员会的讨论结果,

WPF 依赖属性概念

理解依赖属性 在 WPF 中变成相比较于 传统 Windows Forms 变成发生了较大的改变. 属性现在以一组服务的形式提供给开发人员. 这组服务就叫做属性系统. 由 WPF 属性系统所支持的属性成为依赖属性. 依赖属性的概念 WPF 在依赖属性中提供了标准属性无法提供的功能, 特性如下: 决定属性值: 依赖属性的属性值可以在运行时有其他元素或者是其他信息所决定, 决定的过程具有一个优先次序. 自动验证或变更通知: 依赖属性哟一个自定的回调方法, 当属性值变更时被执行, 这个回调能验证新的值

Docker的概念及剖析原理和特点

一.docker的简介: 应用容器是个啥样子呢,一个做好的应用容器长的就像一个装好了一组特定应用的虚拟机一样,比如我现在想用mysql数据库,我直接找个装好了的MySQL的容器就可以了,想用的时候一运行容器,MySQL服务就起来了,就可以使用MySQL了 为什么不能直接安装一个MySQL?或者是SqlServer呢也可以啊? 答:因为有的时候根据每个人的电脑的不同,在物理机安装的时候会出现各种各样的错误,突然你的机器中病毒了或者是挂了,你所有的服务都需要重新安装. 注意:    但是有了dock

老男孩教育每日一题-2017年5月11-基础知识点: linux系统中监听端口概念是什么?

1.题目 老男孩教育每日一题-2017年5月11-基础知识点:linux系统中监听端口概念是什么? 2.参考答案 监听端口的概念涉及到网络概念与TCP状态集转化概念,可能比较复杂不便理解,可以按照下图简单进行理解? 将整个服务器操作系统比喻作为一个别墅 服务器上的每一个网卡比作是别墅中每间房间 服务器网卡上配置的IP地址比喻作为房间中每个人 而房间里面人的耳朵就好比是监听的端口 当默认采用监听0.0.0.0地址时,表示房间中的每个人都竖起耳朵等待别墅外面的人呼唤当别墅外面的用户向房间1的人呼喊时

Tensorflow一些常用基本概念与函数(四)

摘要:本系列主要对tf的一些常用概念与方法进行描述.本文主要针对tensorflow的模型训练Training与测试Testing等相关函数进行讲解.为'Tensorflow一些常用基本概念与函数'系列之四. 1.序言 本文所讲的内容主要为以下列表中相关函数.函数training()通过梯度下降法为最小化损失函数增加了相关的优化操作,在训练过程中,先实例化一个优化函数,比如 tf.train.GradientDescentOptimizer,并基于一定的学习率进行梯度优化训练: optimize

Tensorflow一些常用基本概念与函数(三)

摘要:本系列主要对tf的一些常用概念与方法进行描述.本文主要针对tensorflow的数据IO.图的运行等相关函数进行讲解.为'Tensorflow一些常用基本概念与函数'系列之三. 1.序言 本文所讲的内容主要为以下相关函数: 操作组 操作 Data IO (Python functions) TFRecordWrite,rtf_record_iterator Running Graphs Session management,Error classes 2.tf函数 2.1 数据IO {Da

数据结构基础概念

1.数据的特点:可以输入到计算机,可以被计算机程序处理 2.数据是一个抽象的概念,将其进行分类后得到程序设计语言中的类型.如:int float char等等 3.数据元素-组成数据的基本单位,数据项:一个数据元素由若干数据项组成 4.数据对象 -性质相同的数据元素的集合 5.数据元素之间不是独立的,存在特定的关系,这些关系即结构 6.数据结构指数据对象中数据元素之间的关系,编写一个"好"的程序之前,必须分析待处理问题中各个对象的特性,以及对象之间的关系 7.逻辑结构 集合结构--数据