【持续集成】使用 Jenkinsfile 设计直观的 Pipeline

在编写《Growth:全栈 Web 开发思想》的时候,发现了Jenkins 2.0 发现了一个很帅的插件,叫Blue Ocean。

提供了一个高大上的可视化界面,如下:

【持续集成】使用 Jenkinsfile 设计直观的 Pipeline
超级直观,有木有,构建流程一目了然。于是,我也做了一个玩玩:【持续集成】使用 Jenkinsfile 设计直观的 Pipeline

简单的来说,就是编写 Jenkinsfile,即 Pipeline as Code。

Jenkinsfile

Jenkinsfile 是一种基于 Groovy 的 DSL,和 Gradle 的设计思想是一样的,我们也可以编写 Groovy 插件作为扩展。

而一个 Jenkinsfile 也相当的直观,如下是我在书中编写的代码示例:

 
 
  1. node {

  2.  stage ('Checkout') {

  3.    git 'https://github.com/phodal/growth-studio'

  4.  }

  5.  stage ('Create Virtualenv') {

  6.    sh './ci/setup.sh'

  7.  }

  8.  stage ('Install') {

  9.    sh './ci/install.sh'

  10.  }

  11.  stage ('Unit Test') {

  12.    sh './ci/unit_test.sh'

  13.  }

  14.  stage ('E2E Test') {

  15.    sh './ci/e2e.sh'

  16.  }

  17.  stage ('Deploy') {

  18.    sh './ci/deploy.sh'

  19.  }

  20. }

上面的每一步里,都是由一个简单的脚本来构成的。在运行的时候,我们可以做到下面的效果:

各个阶段的运行时间一目了然。

连失败也变得很优雅,如下是 Blue Ocean 提供的失败示例:

或者使用 Pipeline Stage View 插件时的效果:

而我们所做的只需要在创建项目的时候,选择 Pipeline,并选择 Jenkinsfile 的来源即可:

我总觉得 Atlassian  家的 Bamboo 对持续交付做得更好一些——我是说手动点部署。不过它是收费的,还不便宜~~。

示例代码:https://github.com/phodal/growth-code

阅读原文

【持续集成】使用 Jenkinsfile 设计直观的 Pipeline》来自互联网,仅为收藏学习,如侵权请联系删除。本文URL:http://www.hashtobe.com/3700.html