Jenkins 流水线(Pipeline)详解

        大家好,Jenkins 流水线(Pipeline)是一种可编排的持续集成和交付(CI/CD)方法,它以代码的方式定义整个软件开发过程中的构建、测试和部署流程。接下来就跟大家分享一下Jenkins 流水线(Pipeline)。

关于Jenkins安装可以参考:

使用Docker安装Jenkins

一、介绍

        Jenkins 流水线(Pipeline)是一种持续集成和交付(CI/CD)工具,它以代码的方式定义整个软件开发过程中的构建、测试和部署流程。与传统的 Jenkins 项目和自由风格项目相比,Jenkins 流水线具有以下显著特点和优势:

  1. 可编排性(Orchestration): 流水线允许用户通过编写脚本来定义软件开发过程中的整个流程,包括构建、测试、部署等环节的顺序和依赖关系,实现了对整个流程的可编排性和可控性。

  2. 可追溯性(Traceability): 流水线通过将整个软件开发过程的定义存储在版本控制系统中,实现了对每一次构建的全面追踪和记录,包括每个阶段的执行结果、日志输出等信息,方便用户进行问题排查和分析。

  3. 可重用性(Reusability): 流水线通过提供一系列的 Pipeline DSL(Domain-Specific Language)来定义流水线的各个阶段和任务,使得用户可以编写可重用的模块和函数,方便流水线的复用和扩展。

  4. 可视化(Visualization): 流水线提供了直观的可视化界面来展示流水线的执行过程和结果,包括阶段的执行状态、耗时、触发原因等信息,方便用户实时监控和管理流水线的运行情况。

  5. 灵活性(Flexibility): 流水线允许用户根据具体的需求和场景定制和调整流水线的配置,包括添加、删除、修改阶段和任务,调整触发条件和参数配置等,实现了对流水线的灵活性和定制性。

        Jenkins 流水线为软件开发团队提供了一种灵活、可控、可视化的持续集成和交付解决方案,帮助团队更好地管理和优化软件开发过程,提高开发效率和质量。

二、Pipeline 插件

        Pipeline 插件是 Jenkins 中用于创建和管理流水线的核心插件,它提供了一种强大而灵活的方式来定义整个软件开发过程中的构建、测试和部署流程。

1、插件安装

        Pipeline 插件是 Jenkins 的默认安装插件之一,通常在安装 Jenkins 后就会自动包含。如果你的 Jenkins 没有安装 Pipeline 插件,可以通过 Jenkins 管理界面的插件管理功能进行安装。

2、Pipeline DSL

        Pipeline 插件引入了一种名为 Pipeline DSL(Domain-Specific Language)的脚本语言,它是基于 Groovy 语言的,并提供了一系列关键字和语法来定义流水线的各个阶段和任务。Pipeline DSL 主要包括以下几个核心概念:

  • pipeline:定义整个流水线的入口,包括流水线的名称、参数、触发条件等信息。
  • stage:定义流水线的一个阶段,包括阶段的名称、任务、并行执行等信息。
  • step:定义流水线的一个任务,可以是构建、测试、部署等操作。
  • node:指定流水线的执行节点,可以是 Jenkins 主节点或者代理节点。
  • agent:指定流水线的代理节点,即流水线的执行环境。
  • parameters:定义流水线的参数,可以在流水线执行时传入不同的参数值。

3、Pipeline 编写

编写 Pipeline 脚本通常分为以下几个步骤:

  1. 定义流水线:使用 pipeline 关键字定义流水线,并设置流水线的参数和触发条件。
  2. 定义阶段:使用 stage 关键字定义流水线的各个阶段,并设置阶段的名称和任务。
  3. 编写任务:在每个阶段中使用 steps 或其他任务相关的关键字来编写具体的任务脚本,如构建、测试、部署等。
  4. 设置代理节点:如果需要在特定的节点上执行任务,可以使用 agentnode 关键字来设置执行节点。
  5. 参数化:如果流水线需要接受外部参数,可以使用 parameters 关键字定义参数列表,并在流水线执行时传入参数值。

4、示例

下面是一个简单的 Pipeline 脚本示例,演示了一个简单的构建和测试流水线:

pipeline {agent anystages {stage('Build') {steps {sh 'mvn clean package'}}stage('Test') {steps {sh 'mvn test'}}}
}

        以上示例定义了一个包含两个阶段(Build 和 Test)的流水线,其中 Build 阶段用于执行 Maven 构建,Test 阶段用于执行 Maven 测试。这个示例演示了如何使用 Pipeline 插件来创建和管理流水线,以及如何编写简单的 Pipeline 脚本来定义流水线的各个阶段和任务。

三、Pipeline 脚本语法

        Pipeline 脚本语法是 Pipeline 插件提供的一种特定语法,用于编写 Jenkins 流水线的各个阶段和任务。

1、Stage(阶段)

Stage 是流水线中的一个逻辑单元,用于将流水线划分为不同的阶段,如构建、测试、部署等。

使用 stage 关键字定义一个阶段,并指定阶段的名称。

pipeline {agent anystages {stage('Build') {steps {// 构建步骤}}stage('Test') {steps {// 测试步骤}}// 更多阶段...}
}

2、Step(步骤)

Step 是流水线执行的最小单元,用于执行具体的任务,如构建项目、运行测试、发送通知等。

使用不同的关键字或函数来定义一个步骤,如 sh(执行 Shell 命令)、echo(输出信息)、git(Git 操作)等。

pipeline {agent anystages {stage('Build') {steps {sh 'mvn clean package'}}stage('Test') {steps {echo 'Running unit tests...'sh 'mvn test'}}// 更多步骤...}
}

3、Parallel(并行执行)

Parallel 允许将多个步骤或阶段并行执行,以提高流水线的执行效率。

使用 parallel 关键字将多个步骤或阶段包裹起来,并在其中定义需要并行执行的任务。

pipeline {agent anystages {stage('Test') {parallel {stage('Unit Tests') {steps {// 执行单元测试}}stage('Integration Tests') {steps {// 执行集成测试}}}}}
}

4、Node(节点)

Node 用于指定流水线的执行节点,即流水线的执行环境,可以是 Jenkins 主节点或代理节点。

使用 nodeagent 关键字指定执行节点,并在其中定义流水线的各个阶段和任务。

pipeline {agent {label 'my-agent' // 指定代理节点}stages {stage('Build') {steps {// 构建步骤}}// 更多阶段...}
}

四、流水线基础

        在 Jenkins 中创建简单的流水线通常涉及以下几个步骤:定义流水线的结构、设置环境变量、编写脚本以及运行流水线。

1、定义流水线结构

首先需要定义流水线的结构,包括流水线的名称、代理节点、阶段和步骤等。

下面是一个简单的流水线定义示例,包括了一个构建阶段和一个测试阶段。

pipeline {agent any // 使用任意可用的代理节点stages {stage('Build') { // 定义构建阶段steps {echo 'Building...'sh 'make build'}}stage('Test') { // 定义测试阶段steps {echo 'Testing...'sh 'make test'}}}
}

2、设置环境变量

可以在流水线中设置环境变量,用于在流水线执行过程中传递参数、配置选项等。

下面示例演示了如何设置一个环境变量并在流水线的步骤中使用。

pipeline {agent anyenvironment {NAME = 'John' // 设置一个环境变量}stages {stage('Print') {steps {echo "Hello, ${NAME}!" // 使用环境变量}}}
}

3、编写流水线脚本

在流水线的各个阶段中编写脚本来实现具体的构建、测试、部署等任务。

下面示例展示了一个简单的流水线,其中包括了一个构建阶段和一个测试阶段,并在每个阶段中执行了一些命令。

pipeline {agent anystages {stage('Build') {steps {echo 'Building...'sh 'make build'}}stage('Test') {steps {echo 'Testing...'sh 'make test'}}}
}

4、运行流水线

        在 Jenkins 中,可以通过在 Jenkins 界面上选择相应的流水线项目并点击“构建”按钮来手动触发流水线的执行。也可以通过配置触发器来实现自动触发流水线的执行,如定时触发、代码提交触发等。

        手动触发流水线的执行通常在 Jenkins 界面上进行,点击流水线项目的“构建”按钮即可。自动触发流水线的执行需要在流水线项目的配置中配置相应的触发器,如下:

pipeline {triggers {cron('H/5 * * * *') // 每隔 5 分钟触发一次流水线执行}...
}

五、流水线高级特性

        在 Jenkins 中,流水线不仅可以实现简单的构建和测试任务,还可以利用一些高级特性来增强流水线的灵活性、可维护性和扩展性。下面详细介绍几种流水线的高级特性,并提供相应的示例代码。

1、参数化构建

参数化构建允许在流水线执行时传递参数值,使得流水线具有更大的灵活性。

下面是一个示例,演示了如何定义一个参数化的流水线,其中包括一个字符串类型的参数 ENVIRONMENT,用于指定环境名称。

pipeline {parameters {string(name: 'ENVIRONMENT', defaultValue: 'production', description: 'Environment name')}agent anystages {stage('Build') {steps {echo "Building for environment: ${params.ENVIRONMENT}"}}}
}

2、流水线共享库

流水线共享库允许将常用的流水线代码封装为可复用的库,并在多个流水线项目中共享和引用。

创建一个名为 vars 的目录,并在其中编写一个 Groovy 脚本文件(如 utils.groovy),定义一个名为 sayHello 的全局函数,然后在流水线脚本中引用该函数:

// vars/utils.groovy
def call() {echo 'Hello, world!'
}
// Jenkinsfile
@Library('my-shared-library') _
pipeline {agent anystages {stage('Test') {steps {utils.sayHello()}}}
}

3、异常处理

异常处理允许在流水线执行过程中捕获和处理异常情况,以实现更健壮的流水线。

下面示例展示了如何使用 try-catch 块来捕获异常,并在出现异常时执行相应的处理逻辑。

pipeline {agent anystages {stage('Deploy') {steps {script {try {sh 'deploy.sh'} catch (Exception e) {echo "Failed to deploy: ${e.message}"currentBuild.result = 'FAILURE'}}}}}
}

4、日志记录

日志记录允许在流水线执行过程中输出自定义的日志信息,以便在 Jenkins 界面中查看流水线的执行日志。

下面示例展示了如何使用 echo 函数输出自定义的日志信息。

pipeline {agent anystages {stage('Build') {steps {echo 'Building...'sh 'make build'}}}
}

六、与源代码管理集成

        将流水线与版本控制系统(如 Git、SVN 等)集成可以实现当代码发生变更时自动触发流水线的执行,从而实现持续集成和持续交付。

1、Git 集成

        Git 是目前最流行的版本控制系统之一,在 Jenkins 中配置 Git 集成可以实现当代码提交或分支变更时自动触发流水线的执行。

        下面是一个简单的流水线配置示例,其中包括了 Git 集成,使用了 checkout 步骤来拉取代码并切换到指定分支。

pipeline {agent anystages {stage('Checkout') {steps {checkout([$class: 'GitSCM', branches: [[name: 'master']], userRemoteConfigs: [[url: 'https://github.com/myuser/myrepo.git']]])}}stage('Build') {steps {sh 'make build'}}}
}

2、SVN 集成

        SVN 是另一种常用的版本控制系统,与 Git 类似,通过配置 SVN 集成可以实现当代码提交或分支变更时自动触发流水线的执行。

        下面是一个简单的流水线配置示例,其中包括了 SVN 集成,使用了 checkout 步骤来拉取代码并切换到指定路径。

pipeline {agent anystages {stage('Checkout') {steps {svn 'https://svn.example.com/svn/repo/trunk'}}stage('Build') {steps {sh 'make build'}}}
}

3、高级配置

        除了简单的拉取代码外,还可以配置更多高级选项,如指定分支、拉取代码的深度、使用认证信息等。

例如:

pipeline {agent anystages {stage('Checkout') {steps {git branch: 'main', credentialsId: 'my-git-credentials', url: 'https://github.com/myuser/myrepo.git'}}// 其他阶段...}
}

七、与测试框架集成

将流水线与测试框架集成可以实现自动执行测试并生成测试报告,从而实现持续集成和持续交付。

1、JUnit 集成

        JUnit 是 Java 平台上广泛使用的单元测试框架,通过配置 JUnit 集成可以在流水线执行过程中自动执行单元测试,并生成 JUnit 格式的测试报告。

        下面是一个简单的流水线配置示例,其中包括了 JUnit 集成,使用了 junit 步骤来执行单元测试并生成测试报告。

pipeline {agent anystages {stage('Build') {steps {sh 'make build'}}stage('Test') {steps {sh 'make test'}post {always {junit 'target/surefire-reports/*.xml'}}}}
}

2、TestNG 集成

        TestNG 是 Java 平台上的另一个流行的测试框架,与 JUnit 类似,通过配置 TestNG 集成可以在流水线执行过程中自动执行测试并生成测试报告。

        下面是一个简单的流水线配置示例,其中包括了 TestNG 集成,使用了 testng 步骤来执行测试并生成测试报告。

pipeline {agent anystages {stage('Build') {steps {sh 'make build'}}stage('Test') {steps {sh 'make test'}post {always {testng 'target/surefire-reports/*.xml'}}}}
}

3、Selenium 集成

        Selenium 是用于自动化 Web 应用程序测试的工具,通过配置 Selenium 集成可以在流水线执行过程中自动执行 Web UI 测试,并生成测试报告。

        下面是一个简单的流水线配置示例,其中包括了 Selenium 集成,使用了 sh 步骤来执行 Selenium 测试脚本。

pipeline {agent anystages {stage('Build') {steps {sh 'make build'}}stage('Test') {steps {sh 'make test'}post {always {sh 'python selenium_tests.py'}}}}
}

八、与部署工具集成

将流水线与部署工具集成可以实现自动化部署和发布,从而实现持续交付和持续部署。

此处将介绍两个常用的部署工具,具体可以参考:

Jenkins Pipeline常用插件整理

1、Docker 集成

        Docker 是一个流行的容器化平台,通过配置 Docker 集成可以在流水线执行过程中构建、打包和发布 Docker 镜像。

        下面是一个简单的流水线配置示例,其中包括了 Docker 集成,使用了 Docker Pipeline 插件提供的 docker.builddocker.push 步骤来构建和发布 Docker 镜像。

pipeline {agent anystages {stage('Build') {steps {script {docker.build('my-image:latest')}}}stage('Push') {steps {script {docker.withRegistry('https://docker.example.com', 'docker-credentials') {docker.image('my-image:latest').push()}}}}}
}

2、Kubernetes 集成

        Kubernetes 是一个开源的容器编排平台,通过配置 Kubernetes 集成可以在流水线执行过程中部署和管理容器化应用。

        下面是一个简单的流水线配置示例,其中包括了 Kubernetes 集成,使用了 Kubernetes Pipeline 插件提供的 kubectl 步骤来部署应用到 Kubernetes 集群。

pipeline {agent anystages {stage('Deploy') {steps {script {kubernetesDeploy(kubeconfigId: 'my-kube-config',configs: 'kube/*.yml')}}}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/841923.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2024年5月26日 (周日) 叶子游戏新闻

资深开发者:3A游戏当前处于一种尴尬的中间地带游戏行业整体,尤其是3A游戏正处于艰难时期。尽管2023年3A游戏佳作频出,广受好评,但居高不下的游戏开发成本(传闻《漫威蜘蛛侠2》的制作成本高达3亿美元)正严重…

【机器学习结合AI绘画工具】——开启艺术创作的新纪元

目录 一、AI绘画工具的发展历程 二、AI绘画工具的技术原理 实例说明 三、AI绘画工具在艺术创作中的应用 实例网站 四、AI绘画工具的影响与未来展望 结论 机器学习和人工智能(AI)在过去的十年里取得了显著的进展。特别是在艺术创作领域&#xff0c…

【笔记】太久没有写selenium了

以前qyqt和selenium用来开发一个自动化测试工具,现在回忆一下已经过了将近6年。 DeprecationWarning: find_element_by_* commands are deprecated. Please use find_element() 例如:find_element_by_xpath改为web.find_element(By.XPATH from seleniu…

excel表格写存神器--xlwt

原文链接:http://www.juzicode.com/python-tutorial-xlwt-excel 在 Python进阶教程m2d–xlrd读excel 中我们介绍了Excel表格的读取模块xlrd,今天这篇文章带大家了解Excel表格写存模块xlwt。他俩名字相近都以Excel的简写xl开头,rd是read的简写…

Java顺序表

Java顺序表 前言一、线性表介绍常见线性表总结图解 二、顺序表概念顺序表的分类顺序表的实现throw具体代码 三、顺序表会出现的问题 前言 推荐一个网站给想要了解或者学习人工智能知识的读者,这个网站里内容讲解通俗易懂且风趣幽默,对我帮助很大。我想与…

金融序列的布朗运动

https://zhuanlan.zhihu.com/p/659164160 python金融衍生品定价系列之一 —— 布朗运动与伊藤公式 导语:网络上和书本上关于期权定价相关的内容已经较为丰富,但将理论和python代码结合起来讲的却很少,这也是python金融衍生品定价系列的写作初衷,在用python实现相关模型的同…

Rating 计算公式

Rating ⁡ \operatorname{Rating} Rating 计算公式一般有多种,具体公式取决于使用情境和数据结构。 常用的环形排序算法的Rating计算公式是: Rating ⁡ R K ( P − E ) \operatorname{Rating} R K\times(P -E) RatingRK(P−E)其中, R …

春秋云境CVE-2018-20604

简介 雷风影视CMS是一款采用PHP基于THINKPHP3.2.3框架开发,适合各类视频、影视网站的影视内容管理程序,该CMS存在缺陷,可以通过 admin.php?s/Template/edit/path/*web*..*..*..*..*1.txt 的方式读取任意文件。 正文 1.进入靶场 2./admin…

AI学习指南数学工具篇-凸优化在支持向量机(SVM)中的应用

AI学习指南数学工具篇-凸优化在支持向量机(SVM)中的应用 在机器学习领域中,支持向量机(SVM)是一种经典的监督学习算法。SVM通过寻找最佳的超平面来进行分类,其优化核心是基于凸优化理论。本文将详细介绍凸…

【数据结构】二叉树-堆(上)

个人主页~ 二叉树-堆 一、树的概念及结构1、概念2、相关概念3、树的表示4、树的实际应用 二、二叉树的概念和结构1、概念2、特殊二叉树3、二叉树的性质4、二叉树的存储结构(1)顺序存储(2)链式存储 三、二叉树的顺序结构以及实现1、…

【C++】——入门基础知识超详解

目录 ​编辑 1.C关键字 2. 命名空间 2.1 命名空间定义 2.2 命名空间使用 命名空间的使用有三种方式: 注意事项 3. C输入&输出 示例 1:基本输入输出 示例 2:读取多个值 示例 3:处理字符串输入 示例 4:读…

Python并发编程大揭秘:打造你的多任务处理超能战队!

今天给大家带来的是学习如何构建一个能够同时处理海量任务的超级团队。从简单的线程和锁,到复杂的异步IO和多进程部署,每一个工具都像是你团队中的一员,各有所长,共同协作! 文章目录 Python进阶之并发和并行编程详解1.…

【Linux-INPUT输入的子系统】

Linux-INPUT输入的子系统 ■ input 子系统简介■ input 驱动编写流程■ ■ input 子系统简介 input 子系统就是管理输入的子系统, input 子系统分为 input 驱动层、 input 核心层、 input 事件处理层,最终给用户空间提供可访问的设备节点 ■ input 驱…

leetcode打卡#day39 738. 单调递增的数字

738. 单调递增的数字 class Solution { public:int monotoneIncreasingDigits(int N) {string strNum to_string(N);// flag用来标记赋值9从哪里开始// 设置为这个默认值,为了防止第二个for循环在flag没有被赋值的情况下执行int flag strNum.size();for (int i …

【Linux-中断】

Linux-中断 ■■■ ■■■ ■■■ ■ ■ ■ ■ ■ ■ ■ ■ ■

React类组件生命周期详解

在React的类组件中,从组件创建到组件被挂载到页面中,这个过程react存在一系列的生命周期函数,最主要的生命周期函数是componentDidMount、componentDidUpdate、componentWillUnmount 生命周期图例如下 1. componentDidMount组件挂载 如果你…

S1E45:单链表1 课后作业

测试题:0. 相比起数组来说,单链表具有哪些优势呢? 答:长度非固定,可以申请添加长度 答案:对于数组来说,随机插入或者删除其中间的某一个元素,都是需要大量的移动操作,而…

网络攻击攻击之-远程命令执行/RCE告警运营分析篇

在各种网络安全产品的告警中,远程命令执行是一种非常常见的告警。本文将从远程命令执行的定义,远程命令执行利用的流量数据包示例,远程命令执行的suricata规则,远程命令执行的告分析警研判,远程命令执行的处置建议等几个方面阐述如何通过IDS/NDR,态势感知等流量平台的远程…

深入解析RPC技术:原理、实现与应用

RPC(Remote Procedure Call,远程过程调用)是一种计算机通信协议,允许一个程序(客户端)在本地调用另一个程序(服务器)中的函数或方法,并获取返回结果,就像调用…

栈和队列的区别

栈和队列是两种常用的数据结构,它们在数据的存取方式、适用场景和基本操作上有显著的区别。以下是它们的详细区别: 1. 存取方式 栈(Stack): 后进先出(LIFO, Last In First Out):最…