专栏首页晓晨的专栏Jenkins高级用法 - Jenkinsfile 介绍及实战经验

Jenkins高级用法 - Jenkinsfile 介绍及实战经验

一.什么是 Jenkinsfile

Jenkinsfile 是 Jenkins 2.x 核心特性 Pipeline 的脚本,由Groovy语言实现。Jenkinsfile一般是放在项目根目录,随项目一起受源代码管理软件控制,无需像创建“自由风格"(Jenkins FreeStyle)项目一样,每次可能需要拷贝很多设置到新项目,提供了一些直接的好处:

  • Pipeline上的代码审查/迭代
  • Pipeline的审计跟踪
  • Pipeline的唯一真实来源,可以由项目的多个成员查看和编辑。

Pipeline支持:Declarative(在Pipeline 2.5中引入)和Scripted Pipeline两种格式。两者都支持建立Pipeline,两者都可以用于在Web UI中定义一个流水线Jenkinsfile,将Jenkinsfile文件创建并检查到源代码控制库中通常被认为是最佳做法。

更多详细信息参考:玩转Jenkins Pipeline(大宝鱼) 推荐必读

二. Jenkinsfile 实战经验

看本小节之前,如果你不熟悉 Jenkinsfile 那么推荐一定要阅读,第一小节推荐的文章,里面介绍了很多基本用法。

这里的实战主要讲声明式 Jenkinsfile,因为声明式 Jenkinsfile是 Pipeline 2.5 引入的,比之以前的脚本式会有一些更先进的设计和更快捷的用法,且声明式Jenkinsfile还兼容脚本式语法。这里主要讲一些博主实际用的过程中的经验。

1.在指定的Jenkins集群结点上运行

pipeline {
    agent {
        node {
            label 'slave-1'
        }
    }
}

label 指你的集群结点名称

2.定义环境变量

pipeline {
    environment {
        NUGET_KEY     = 'abc'
    }
}

使用:

env.NUGET_KEY

sh里使用

$NUGET_KEY

例子:

输出该环境变量

echo "${env.NUGET_KEY}"

sh:

sh 'echo $NUGET_KEY'

这里要注意在 sh 语句块里使用的不同。

3.设置 github webhook 触发器

triggers {
      githubPush()
}

UI上没有没有设置github webhook触发的。脚本设置后,需要到 【系统管理】->【系统设置】里,手动注册一下github webhook即可

4.常用的预置环境变量

变量名

说明

BRANCH_NAME

当前分支名称

GIT_COMMIT

当前 commit hash

GIT_PREVIOUS_SUCCESSFUL_COMMIT

上一次构建成功 cimmit hash

示例:

echo "branch: ${env.BRANCH_NAME}"
echo "current SHA: ${env.GIT_COMMIT}"
echo "previous SHA: ${env.GIT_PREVIOUS_SUCCESSFUL_COMMIT}"script

5.script块

script 块里可以写脚本式Jenkinsfile的语法

例子:

stages {
        stage('Build') {
            steps {
                script {
                    result = sh (script: "git log -1|grep 'Release'", returnStatus: true) 
                    echo "result: ${result}"
                }
            }
        }
    }

6.设置构建结果

post { always { script { currentBuild.result = 'NOT_BUILT' } } }

一般放在 POST 语句块

7.敏感数据设置

一些敏感数据,比如账号密码,不可能卸载脚本中。

首先新建凭据(Jenkins 地址 /credentials/store/system/domain/_/):

类型选择 Secret text,Secret 输出你的 账号/密码等。然后记住你设置的ID,待会要用

可以通过 credentials函数来获取

credentials('<凭据id>')

例如

credentials('test')

直接输出到控制台也会加密:

8.定义变量

def cusversion="Jenkinsfile"

必须放在 pipeline 前面或者 script 语句块里面

9.指定分支运行stage

stage('Deploy') {
            when {
                branch "<分支名称>"
            }
}

三.扩展阅读

Jenkinsfile 语法 https://jenkins.io/doc/book/pipeline/syntax

玩转Jenkins Pipeline https://blog.csdn.net/diantun00/article/details/81075007

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Jenkins高级教程 - Pipeline 安装

    Pipeline,简而言之,就是一套运行于Jenkins上的工作流框架,将原本独立运行于单个或者多个节点的任务连接起来,实现单个任务难以完成的复杂流程编排与可视...

    晓晨
  • .NET Core 获取操作系统各种信息

    晓晨
  • 浏览器启动外部软件

    晓晨
  • 事务的概念

    我们在实际业务场景中,经常会遇到数据频繁修改读取的问题。在同一时刻,不同的业务逻辑对同一个表数据进行修改,这种冲突很可能造成数据不可挽回的错乱,所以我们需要用事...

    用户1205080
  • Spark:超越Hadoop MapReduce

    大数据对一些数据科学团队来说是主要的挑战,因为在要求的可扩展性方面单机没有能力和容量来运行大规模数据处理。此外,即使专为大数据设计的系统,如 Hadoop,由于...

    博文视点Broadview
  • 经典论文复现 | 基于标注策略的实体和关系联合抽取

    过去几年发表于各大 AI 顶会论文提出的 400 多种算法中,公开算法代码的仅占 6%,其中三分之一的论文作者分享了测试数据,约 54% 的分享包含“伪代码”。...

    用户1386409
  • Hadoop和Spark的异同

    解决问题的层面不一样 Hadoop实质上是解决大数据大到无法在一台计算机上进行存储、无法在要求的时间内进行处理的问题,是一个分布式数据基础设施。 HDFS,它将...

    企鹅号小编
  • Redis使用Pipeline加速查询速度

    Redis 是一种基于客户端-服务端模型以及请求/响应协议的TCP服务。这意味着通常情况下 Redis 客户端执行一条命令分为如下四个过程:

    smartsi
  • Java 8 Stream 教程 (一)

    作者:Benjamin 译者:java达人 来源:http://winterbe.com/posts/2014/07/31/java8-stream-tut...

    java达人
  • spark与hadoop相比,存在哪些缺陷(劣势)

    一说大数据,人们往往想到Hadoop。这固然不错,但随着大数据技术的深入应用,多种类型的数据应用不断被要求提出,一些Hadoop被关注的范畴开始被人们注意,相关...

    用户1410343

扫码关注云+社区

领取腾讯云代金券