什么是Buildbot

Buildbot是一个持续集成和自动化测试框架,我在毕业刚进VMware不久的一个和以色列人合作的项目中接触到Buildbot,当时我真的恨死它了。。。经常随意的提交了一些代码后,Buildbot就开始勤勤恳恳的把所有的代码下载下来然后跑各种测试,跑完后出现错误还会自动发E-mail给我,和我的上级!!!特别是当时和以色列人合作,好几次下班前提交了代码后我就回家了(好吧,我没耐心等那么多测试跑完啊,总是要跑半个多小时,而且那时候做事很急躁),然后Break Build了。等我第二天开开心心来到公司,看到一堆以色列人询问的邮件(因为时差,我们下班了他们才开始上班)。当时真的脸比猴屁股还红。。。

现在当我自己出来做事时,才真的重新爱上了它。自动化测试和持续集成真是太重要了,时过境迁,我变成了那个挥着Buildbot的小皮鞭的恶人了。。

Buildbot能做什么?

一个常见的场景是用BuildBot绑定到你所使用的VCS,比如Git仓库。然后当有人提交了Code change时,会触发BuildBot去拉下最新的code,然后Compile, Build,再跑你定义的一系列tests。最酷的是BuildBot自带了一个HTML的Web Report功能,其中的Waterfall会以瀑布流的形式向你展示所有的任务,如果有错误发生可以直接查看相关的各种信息,非常直观好用,谁是背后的凶手一目了然。。。

Buildbot基本结构

BuildBot的常用架构是一个Master和一堆Slave,Master负责对接VCS,然后管理调度各个Slave各司其职,收集Slave传回来的数据并且整理成报告。Slave负责按照Master发过来的命令跑各种任务,并将环境信息,结果,log文件等收集起来报告给Master。

  • master

    master就是Buildbot的核心,我们使用Buildbot所需要做的各种工作也是在Master上进行。

    Buildbot的使用方式就是在Master上编辑master.cfg文件,这其实是一个Python文件。使用者在里面定义对接的VCS,Schedule和Build的各种条件以及具体的Build任务,结果的收集报告方式等。
  • slave

    当slave连接到master后就会不断跟master进行通信。当有任务时,master会将命令逐个发送给slave执行。

一个Buildbot例子

现在我们来搭一个最简单的Buildbot实例,我手头用的操作系统是ubuntu12.04, python3.5。

首先,用virtualenv做了一个环境(不打算用virtualenv的人可以直接跳过这些步骤)

  1. mkdir -p tmp/buildbot
  2. cd tmp/buildbot
  3. virtualenv --no-site-packages sandbox
  4. source sandbox/bin/activate

然后我们安装buildbot:

  1. easy_install sqlalchemy==0.7.10
  2. easy_install buildbot

安装成功后,我们先创建master,并且就使用默认的master.cfg文件

  1. buildbot create-master master
  2. mv master/master.cfg.sample master/master.cfg

这时候你会看到当前目录里多了一个master文件夹。接下来我们创建slave

  1. easy_install buildbot-slave
  2. buildslave create-slave slave localhost:9989 example-slave pass

现在当前目录里又多了一个slave文件夹,最后我们启动master和slave

  1. buildbot start master
  2. buildslave start slave

接下来你就可以在http://localhost:8010/看到Buildbot页面了,点击页面上的waterfall,或者访问http://localhost:8010/waterfall就可以看到瀑布流界面。

Buildbot详细说明

虽然刚刚跑通了一个例子(很有可能大部分人还没有跑通。。。),我们还是云里雾里。到底发生了什么?

这里的关键就是master.cfg文件,Buildbot的使用其实就是编辑master.cfg文件。它里面其实是python代码,跑完这个文件会得到BuildmasterConfig对象,就是这个对象最后会指导master完成各种任务。这个文件的一开头就会新建这个对象,然后不断往里面添加各种属性。

  1. c = BuildmasterConfig = {}

接下来我们了解下这个对象涉及到的比较重要的类和他们的作用。

change

change是Buildbot用来跟踪VCS,获取代码变动信息的类。Buildbot针对常见的VCS提供了很多子类供使用调用。比如定期从Git仓库检查代码状况的GitPoller,举个栗子:

  1. c['change_source'] = []
  2. c['change_source'].append(changes.GitPoller(
  3. 'https://url.git',
  4. workdir='', branch='master',
  5. pollinterval=300))

这段代码就是添加了一个每300秒去检测一下url.git是否有改动的changes。

scheduler

注意,并不是有了change就一定会触发Buildbot去做任务,也不是没有change时Buildbot就不会做任何事。Buildbot的运行其实是scheduler来决定的。Buildbot同样提供了很多种scheduler,比如SingleBranchScheduler是用来在收到changes发生时触发任务的,ForceScheduler是用来供使用人员通过Web页面点击按钮强制触发任务的,Periodic是用来固定时间频率触发任务的,同样举个栗子:

  1. c['schedulers'].append(schedulers.SingleBranchScheduler(
  2. name="all",
  3. change_filter=util.ChangeFilter(branch='master'),
  4. treeStableTimer=None,
  5. builderNames=["runtests"]))
  6. c['schedulers'].append(schedulers.ForceScheduler(
  7. name="force",
  8. builderNames=["runtests"]))

这段代码的作用就是添加了两个scheduler,分别在发现master分支有code changes时和收到强制触发命令时触发名为"runtests"的builder,这就引出下一个概念builder。

builder

builders就是负责具体指挥执行Buildbot任务的单位,builder里绑定了它将会使唤的slave和它需要执行的一系列命令。当builder被scheduler触发时,它就会通过tcp去通知响应的slave,督促它们开始做事。下面是master.cfg中注册builder的代码。

  1. c['builders'].append(
  2. util.BuilderConfig(name="runtests",
  3. slavenames=["exchange"],
  4. factory=factory
  5. ))

这个builder将会指挥名为“exchange”的slave,然后执行通过factory生成的步骤。那么factory又是什么?

factory

factory就是告诉builder需要指挥slave做什么的类,我们很大一部分开发量就是在写factory,这里面是我们使用Buildbot的核心业务逻辑所在。

factory通过addStep的方式来添加执行命令,如下面的例子:

  1. factory.addStep(steps.Git(
  2. repourl="https://url.git"
  3. , mode='full'
  4. , method='clobber'
  5. , descriptionDone='code checkout'))
  6. factory.addStep(steps.ShellCommand(
  7. command=['npm', 'install']
  8. , descriptionDone="npm install"))

这个例子生成的factory就会告诉对应builder指挥的slave,你先用Git拉下url.git仓库,然后调用命令npm install

Buildbot提供了大量的命令,详细请参考链接

slaves

这里还有一个环节没打通,slave是怎么连接上master的?

要做到这一点,首先我们需要在master.cfg里配置slaves:

  1. c['slaves'] = [buildslave.BuildSlave("exchange", "exchange")]

这里我们配置了一个名字叫exchange的slave,然后它的密码也是exchange。这样如果有exchange来连接master,说自己叫"exchange",然后密码也对上的时候,master就会认了这个slave(认领slave还需要密码呀。。。)。

那么slave怎么连接master?首先,在master.cfg里我们配置master的监听端口:

  1. c['protocols'] = {'pb': {'port': 9989}}

然后各位还记得我们在新建slave时调用的命令么?

  1. buildslave create-slave slave localhost:9989 example-slave pass

明白了么?这个slave启动后就会去连接localhost:9989,同时它会告诉master自己名字叫"example-slave",密码是"pass"。恩,这个slave如果连我们上述设置的master,master是不会要它的。因为我们没注册这么一个slave。。。

status

最后还有一个概念是status,也就是master如何输出当前报告。默认的master.cfg里配置了一个WebStatus,所以我们才会看到http://localhost:8010会有一个Web页面。

  1. c['status'].append(html.WebStatus(http_port=8010, authz=authz_cfg))

Buildbot初探的更多相关文章

  1. 初探领域驱动设计(2)Repository在DDD中的应用

    概述 上一篇我们算是粗略的介绍了一下DDD,我们提到了实体.值类型和领域服务,也稍微讲到了DDD中的分层结构.但这只能算是一个很简单的介绍,并且我们在上篇的末尾还留下了一些问题,其中大家讨论比较多的, ...

  2. CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探

    CSharpGL(8)使用3D纹理渲染体数据 (Volume Rendering) 初探 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码 ...

  3. 从273二手车的M站点初探js模块化编程

    前言 这几天在看273M站点时被他们的页面交互方式所吸引,他们的首页是采用三次加载+分页的方式.也就说分为大分页和小分页两种交互.大分页就是通过分页按钮来操作,小分页是通过下拉(向下滑动)时异步加载数 ...

  4. JavaScript学习(一) —— 环境搭建与JavaScript初探

    1.开发环境搭建 本系列教程的开发工具,我们采用HBuilder. 可以去网上下载最新的版本,然后解压一下就能直接用了.学习JavaScript,环境搭建是非常简单的,或者说,只要你有一个浏览器,一个 ...

  5. .NET文件并发与RabbitMQ(初探RabbitMQ)

    本文版权归博客园和作者吴双本人共同所有.欢迎转载,转载和爬虫请注明原文地址:http://www.cnblogs.com/tdws/p/5860668.html 想必MQ这两个字母对于各位前辈们和老司 ...

  6. React Native初探

    前言 很久之前就想研究React Native了,但是一直没有落地的机会,我一直认为一个技术要有落地的场景才有研究的意义,刚好最近迎来了新的APP,在可控的范围内,我们可以在上面做任何想做的事情. P ...

  7. 【手把手教你全文检索】Apache Lucene初探

    PS: 苦学一周全文检索,由原来的搜索小白,到初次涉猎,感觉每门技术都博大精深,其中精髓亦是不可一日而语.那小博猪就简单介绍一下这一周的学习历程,仅供各位程序猿们参考,这其中不涉及任何私密话题,因此也 ...

  8. Key/Value之王Memcached初探:三、Memcached解决Session的分布式存储场景的应用

    一.高可用的Session服务器场景简介 1.1 应用服务器的无状态特性 应用层服务器(这里一般指Web服务器)处理网站应用的业务逻辑,应用的一个最显著的特点是:应用的无状态性. PS:提到无状态特性 ...

  9. NoSQL初探之人人都爱Redis:(3)使用Redis作为消息队列服务场景应用案例

    一.消息队列场景简介 “消息”是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含文本字符串:也可以更复杂,可能包含嵌入对象.消息被发送到队列中,“消息队列”是在消息的传输过程中保存消息的容器 ...

随机推荐

  1. mongodb在32位机的连接

    Windows 32bit版本安装Mongodb时,会发生的下面问题 2016-05-09T00:09:45.124+0800 I STORAGE  [initandlisten] exception ...

  2. Windows按名称排序问题

    偶然发现一个按名称排序的文件夹内,文件顺序是混乱的,例如: 在一个文件夹内建立如下三个文件: 0F.txt 1A.txt 02.txt 按名称/升序排列, 将得到上述结果,0F在最前,02在最后. 百 ...

  3. jq 选择器基础及拓展

    jquery 用的很多,所以jq的选择器就很受欢迎,但是用的过程中有一些小问题,如果不点透就永远不知道. 1:ID选择器:$("#ID"); 得到一个指定对应,并且只能得到一个对象 ...

  4. HYSBZ 2565 最长双回文串 (回文树)

    2565: 最长双回文串 Time Limit: 10 Sec  Memory Limit: 128 MB Submit: 1377  Solved: 714 [Submit][Status][Dis ...

  5. phpstrrchr()函数的问题

    strrchr — 查找指定字符在字符串中的最后一次出现 说明 string strrchr ( string $haystack , mixed $needle ) 该函数返回 haystack 字 ...

  6. apktool 工具

      下载 https://code.google.com/p/android-apktool/ apktool_2.0.0rc2.jar 和apktool linux脚本 ln –s apktool_ ...

  7. Python菜鸟之路:Django 文件上传的几种方式

    方式一:通过form表单中,html input 标签的“file”完成 # 前端代码uoload.html <form method="post" action=" ...

  8. T-SQL with关键字 with as 递归循环表

    )SET @OrgId = N'901205CA-6C22-4EE7-AE4B-96CC7165D07F'; WITH Childs AS ( SELECT * FROM HROrgRelation ...

  9. slurm使用

    官方文档:https://slurm.schedmd.com/ 用户命令cheatsheet:https://slurm.schedmd.com/pdfs/summary.pdf 占用GPU sall ...

  10. JavaScript整理1

    JavaScript是一门编程语言,浏览器内置了JavaScript语言的解释器,所以在浏览器上按照JavaScript语言的规则编写相应代码之,浏览器可以解释并做出相应的处理. 一.如何编写 1.J ...