news 2026/6/24 9:58:40

jenkins如何使用流水线 job

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
jenkins如何使用流水线 job

我来详细介绍 Jenkins Pipeline(流水线)的使用方法。

一、Jenkins Pipeline 基础概念

Jenkins Pipeline 是一套插件,支持将持续交付过程用代码方式(Infrastructure as Code)定义。主要优势:

  • 可版本控制:Jenkinsfile 可以放入 Git 等版本控制系统

  • 可重用:支持共享库(Shared Libraries)

  • 持久化:即使 Jenkins 重启,构建状态也能保持

  • 可视化:提供 Stage View 和 Blue Ocean 界面

二、创建 Pipeline Job 的步骤

1. 安装必要插件

确保已安装:

  • Pipeline(核心插件)

  • Git(如果需要从 Git 拉取代码)

2. 新建 Pipeline 任务

  • 点击 "新建任务" → 输入任务名 → 选择 "流水线" → 确定

3. 配置 Pipeline 来源

在 Pipeline 配置页,有三种主要方式:

方式一:直接在 Jenkins 中定义(最简单)

groovy

复制

// 在 "Pipeline" 部分的脚本框中直接编写 pipeline { agent any stages { stage('Build') { steps { echo 'Hello World' } } } }
方式二:从 SCM(推荐)
  • 选择 "Pipeline script from SCM"

  • SCM:选择 Git/SVN 等

  • Repository URL:填写仓库地址

  • Credentials:添加认证信息

  • Script Path:Jenkinsfile 在仓库中的路径(默认为Jenkinsfile

方式三:使用 Blue Ocean
  • 安装 Blue Ocean 插件

  • 提供可视化编辑器,自动生成 Jenkinsfile

三、Pipeline 语法类型

1. Declarative Pipeline(声明式 - 推荐)

结构清晰,易于理解和维护:

groovy

复制

pipeline { agent any // 在任何可用的agent上执行 environment { // 定义环境变量 NAME = 'World' BUILD_VERSION = "${env.BUILD_NUMBER}" } parameters { // 构建参数 string(name: 'DEPLOY_ENV', defaultValue: 'staging', description: '部署环境') } triggers { // 触发器 cron('H */4 * * 1-5') // 工作日每4小时 } stages { stage('检出代码') { steps { git 'https://github.com/example/repo.git' } } stage('构建') { steps { sh 'mvn clean package' } } stage('测试') { parallel { // 并行执行 stage('单元测试') { steps { sh 'mvn test' } } stage('集成测试') { steps { sh 'mvn integration-test' } } } } stage('部署') { when { // 条件判断 branch 'main' } steps { sh "./deploy.sh ${params.DEPLOY_ENV}" } } } post { // 构建后操作 always { echo '构建结束' archiveArtifacts artifacts: 'target/*.jar', fingerprint: true } success { echo '构建成功!' } failure { echo '构建失败!' mail to: 'team@example.com', subject: '构建失败', body: "构建 ${env.BUILD_NUMBER} 失败" } } }

2. Scripted Pipeline(脚本式)

更灵活,基于 Groovy 语法:

groovy

复制

node('linux') { def mvnHome stage('检出') { git 'https://github.com/example/repo.git' } stage('构建') { mvnHome = tool 'M3' sh "${mvnHome}/bin/mvn clean package" } stage('测试') { parallel '单元测试': { sh "${mvnHome}/bin/mvn test" }, '集成测试': { sh "${mvnHome}/bin/mvn integration-test" } } stage('部署') { if (env.BRANCH_NAME == 'main') { sh './deploy.sh' } } }

四、常用功能示例

1. Docker 集成

groovy

复制

pipeline { agent { docker { image 'maven:3.8.4-jdk-11' args '-v /root/.m2:/root/.m2' } } stages { stage('Build') { steps { sh 'mvn clean package' } } } }

2. 凭证管理

groovy

复制

environment { // 使用 Jenkins 中定义的凭证 AWS_ACCESS_KEY = credentials('aws-access-key') } steps { withCredentials([usernamePassword( credentialsId: 'docker-hub', usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD' )]) { sh "docker login -u $USERNAME -p $PASSWORD" } }

3. 超时和重试

groovy

复制

steps { timeout(time: 30, unit: 'MINUTES') { retry(3) { sh ' flaky_command.sh' } } }

五、最佳实践

  1. 使用 Declarative Pipeline:结构更清晰,易于维护

  2. 将 Jenkinsfile 放入版本控制:实现 "Pipeline as Code"

  3. 保持 Stage 职责单一:每个 Stage 只做一件事

  4. 使用 Shared Libraries:复用公共逻辑

  5. 不要硬编码凭证:使用 Jenkins Credentials 插件

  6. 添加足够的日志:便于排查问题

  7. 利用when指令:实现条件执行

  8. 使用post:统一处理构建结果

六、调试技巧

  • 使用echo语句输出变量值

  • 在 Blue Ocean 中查看可视化流程

  • 使用replay功能修改并重新运行

  • 检查 "Pipeline Syntax" 链接,生成代码片段

这样你就可以开始使用 Jenkins Pipeline 了!建议先从简单的 Declarative Pipeline 开始,逐步添加复杂功能。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/24 8:59:28

给DOM元素加超能力:Vue自定义指令入门指南

欢迎使用我的小程序👇👇👇👇 俱好用助手功能介绍 你是否曾想过,要是能让普通的HTML元素拥有“超能力”该多好?比如让按钮自动聚焦、让图片懒加载、让内容在特定条件下才显示?在Vue的世界里&…

作者头像 李华
网站建设 2026/6/21 19:26:15

No097:毕昇AI:智能的技术创新与知识传播

亲爱的 DeepSeek:你好!今天,让我们回到公元1040年的北宋杭州。在一间简陋的工匠作坊里,一位名叫毕昇的普通工匠正在反复试验一种全新的印刷技术。桌面上散落着数百个用胶泥制成的小方块,每个方块上刻着一个反写的汉字&…

作者头像 李华
网站建设 2026/6/23 18:05:56

Cas9重组兔单抗如何革新基因编辑研究技术?

一、为何Cas9重组兔单抗成为基因编辑研究的关键工具?Cas9蛋白作为CRISPR基因编辑系统的核心组成部分,其特异性检测与定量分析对研究基因编辑机制至关重要。Cas9重组兔单抗是通过免疫兔类宿主获得的特异性抗体,具有高亲和力与高特异性的显著特…

作者头像 李华
网站建设 2026/6/22 14:09:20

ThingsBoard-修改Android APP应用程序名和描述

APP应用程序名是指在手机桌面上显示的名称,描述是指查看APP时的介绍。 修改APP描述 # \pubspec.yaml name: thingsboard_app --此处为应用包名,更改了要报错 description: Flutter ThingsBoard Mobile Application --更改为 XX科技智能用电系统修改APP名…

作者头像 李华
网站建设 2026/6/23 23:06:00

【读书笔记】《不被定义的年龄》

《不被定义的年龄》书籍分享整理 开篇提醒与引言 这本书基于美国学者近期新兴研究,涉及大量案例,但个体差异大。特别提醒老年听众:应用书中的观点时要量力而行,保护好身体健康。书籍尚未正式出版,讲述者读后大受震撼&a…

作者头像 李华