尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

实用指南:Jenkins Pipeline 快速开始

实用指南:Jenkins Pipeline 快速开始
📅 发布时间:2026/6/19 11:41:50

一、Jenkins Pipeline 介绍

Jenkins Pipeline 是 Jenkins 的核心插件,用于将软件交付流程(如构建、测试、部署等)定义为可重用、可版本化、可视化的自动化流水线。它通过代码形式(通常是 Groovy 语法)描述整个流程,支持复杂的持续集成 / 持续部署(CI/CD)场景,且流水线定义(Jenkinsfile)可以与代码一起存入版本控制系统(如 Git),实现 “流水线即代码”(Pipeline as Code)。Pipeline 支持两种语法格式:声明式(Declarative Pipeline)和 脚本式(Scripted Pipeline)。

1、优点

  1. 可扩展性:支持复杂流程(如并行执行、条件判断、循环、异常处理等),满足多样化的 CI/CD 需求。
  2. 可维护性:流水线定义以代码形式存储,便于版本控制、评审和复用,避免手动配置的繁琐。
  3. 持久化:即使 Jenkins 重启或构建中断,流水线状态也能保留,支持从断点继续执行。
  4. 可视化:通过 Jenkins 界面直观展示流水线进度、阶段和步骤,便于问题排查。
  5. 集成性:无缝对接 Jenkins 生态的插件(如 Git、Docker、Kubernetes 等),扩展能力强。

2、声明式流水线(Declarative Pipeline)

声明式流水线是 Jenkins 2.5 后推出的简化语法,旨在提供结构化、易读的流水线定义方式。它更接近自然语言,适合大多数标准化的 CI/CD 流程。

核心特点:

  • 固定结构:必须包含在 pipeline 块中,且有明确的阶段划分(agent、stages、steps 等关键字)。
  • 声明式语法:通过关键字描述 “是什么”(如 agent any 表示在任意节点执行),而非 “怎么做”。
  • 内置功能:提供 post 块(定义构建后操作,如成功 / 失败通知)、environment(环境变量)、options(流水线选项)等简化配置的关键字。

示例:

pipeline {agent any  // 在任意可用节点执行environment {VERSION = '1.0.0'  // 定义环境变量}stages {stage('Build') {  // 构建阶段steps {sh 'echo "Building version ${VERSION}"'sh 'mvn clean package'}}stage('Test') {  // 测试阶段steps {sh 'mvn test'}}}post {  // 构建后操作success {echo 'Pipeline succeeded!'}failure {echo 'Pipeline failed!'}}
}

3、脚本式流水线(Scripted Pipeline)

脚本式流水线基于 Groovy 脚本语法,提供更灵活的编程能力,适合复杂、定制化的流程。它更接近传统编程,允许使用 Groovy 的控制结构(如 if-else、for、try-catch 等)。

核心特点:

  • 灵活语法:通过 node 块定义执行节点,无固定结构,可自由组合步骤和逻辑。
  • 编程式控制:支持 Groovy 的所有语法,适合处理动态逻辑(如根据条件选择不同部署环境)。
  • 低约束性:没有声明式的关键字限制,需要手动处理更多细节(如错误处理)。
示例:
node {  // 在节点上执行def version = '1.0.0'  // 定义变量stage('Build') {sh "echo 'Building version ${version}'"sh 'mvn clean package'}stage('Test') {sh 'mvn test'}// 构建后判断if (currentBuild.currentResult == 'SUCCESS') {echo 'Pipeline succeeded!'} else {echo 'Pipeline failed!'}
}

4、区别

维度声明式流水线脚本式流水线
语法风格结构化、声明式(关键字驱动),类似配置文件编程式(Groovy 脚本),类似代码逻辑
灵活性约束性强,适合标准化流程高度灵活,适合复杂、定制化流程
可读性语法简洁,易读易写,适合新手依赖 Groovy 知识,可读性取决于代码质量
错误处理内置 post 块和 options 简化处理需手动编写 try-catch 等逻辑
扩展性依赖预定义关键字,扩展需通过插件可直接调用 Groovy 库和 Jenkins API,扩展性更强
适用场景常规 CI/CD 流程(如构建→测试→部署)复杂逻辑(如动态阶段、条件分支、并行任务嵌套)

5、总结

  • 声明式流水线:推荐新手或标准化流程使用,语法简单、结构清晰,降低维护成本。
  • 脚本式流水线:适合需要高度定制化的场景,灵活但需掌握 Groovy 语法,适合复杂逻辑实现。

实际使用中,两者也可结合(如声明式中嵌入 script 块执行脚本式逻辑),平衡易用性和灵活性。

二、快速案例

Pipeline 5 个必备组成部分

  • pipeline:声明它所包含的内容为一个声明式的pipeline脚本。
  • agent:Jenkins 可以有主从节点,构建起 Jenkins 集群。agent 关键字用来指定 job 执行的节点。不同的节点具有的环境不同,有些节点有 maven 环境,有些节点有 Gradle,所以需要 agent 来指定 job 运行的节点。
  • stages:阶段集合,包裹所有的阶段(例如:打包,部署等各个阶段)。
  • stage:  阶段,被 stages 包裹,一个 stages 可以有多个 stage。
  • steps:  步骤,为每个阶段的最小执行单元,被 stage 包裹。

1、新建流水线任务

Dashboard > 新建 Item 

2、配置流水线

Dashboard > first-pipeline >Configuration

可以选择的流水线定义有两种:

Pipeline script:自己在下面编辑框内编写流水线脚本。

Pipeline script from SCM:从版本管理系统(如:Git)中拉取已经写好的 Jenkinsfile,实现流水线配置的可版本化。 

  • 我们选择 Pipeline script

在右侧下拉选项中,选择 Hello World,以此为基础,编写一个简单的流水线脚本。

脚本如下:

pipeline {agent anystages {stage('拉取代码') {steps {echo '拉取代码结束'}}stage('执行构建') {steps {echo '执行构建结束'}}}
}

agent any 表示当前构建任务可以运行在任一节点上。由 Jenkins 自己决定。

3、运行流水线

保存完流水线后,立即构建

构建完点击任务

点击流水线视图

可以看到 Jenkins 为我们呈现的可视化的流水线,包括每个阶段的耗时以及打印的日志,还可以选择某一阶段重新运行。

4、安装 Blue Ocean 插件

除了 Jenkins 原生的流水线视图外,我们还可以安装 Blue Ocean 插件,它提供了更丰富的功能,和更美观的界面。

Dashboard > Manage Jenkins > Plugins > Available plugins

下载完成后返回首页

打开 Blue Ocean

三、实战案例

Jenkins 实战2:pipeline 流水线实现自动化部署

相关新闻

  • 2025年下半年菜籽油/粮油批发/植物油/食用油批发厂家口碑前五推荐
  • 保姆级教程!PaddleOCR-VL 私有化部署全流程,109 种语言 SOTA 模型直接用
  • 可视化图解算法70:缺失的第一个正整数

最新新闻

  • 武汉买猫买狗去哪看?梦宠山庄实地体验分享 - 园友3800037
  • 从零到一:Jetlinks物联网平台服务器部署实战与避坑指南
  • (转)一次ANSYS EM 2023R1 “Request name electronics_desktop does not exist in the licensing pool.“的离谱解决记录
  • 面试被问“你的缺点是什么”,90%的应届生都答错了!(附满分话术)
  • Spring Cloud Alibaba 最佳实践:基于 Spring Boot 4.0 的完整微服务示例项目
  • 三步掌握AI斗地主:如何用DouZero智能助手提升你的游戏胜率

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号