当前位置: 首页 > news >正文

Jenkins全链路教程——条件判断与流程控制

在Jenkins流水线(Pipeline)中,“动态控制流程”是实现灵活部署、精准测试的核心能力。无论是“仅生产环境执行部署”,还是“合并请求(PR)触发时跳过集成测试”,都需要用到条件判断与流程控制

今天我们就来拆解Jenkins最常用的两种工具:声明式的when指令和脚本式的script块。


一、when与script的核心逻辑

Jenkins Pipeline支持两种主流语法:声明式(Declarative)和脚本式(Scripted)。对应的条件判断工具也不同:

  • • when是声明式Pipeline的“条件控制员”,语法简洁,适合简单规则;

  • • script是脚本式Pipeline的“逻辑全能手”,支持复杂表达式,适合动态计算。

1.1when指令:声明式的“条件开关”

when是声明式Pipeline的专用条件块,直接写在stage中,通过预定义的条件类型(如环境变量、分支名、参数值)控制当前阶段是否执行。

核心特点

  • • 语法固定,仅支持Jenkins预定义的条件类型(如environmentbranchexpression等);

  • • 适合“是否执行某阶段”的简单判断(如“当分支是main时执行部署”);

  • • 条件不满足时,阶段直接跳过(日志显示Stage skipped)。

1.2 script块:脚本式的“逻辑引擎”

script是脚本式Pipeline的核心语法,也可嵌入声明式Pipeline中,通过Groovy脚本实现复杂逻辑(如多条件组合、动态计算变量、调用API等)。

核心特点

  • • 支持完整的Groovy语法(如if-else、循环、函数调用);

  • • 适合“根据动态计算结果决定流程”的复杂场景(如“当测试通过率>90%时继续部署”);

  • • 需注意:在声明式Pipeline中,script需包裹在steps里,避免语法错误。


二、从简单条件到复杂逻辑
🌰 场景1:用when实现基础条件判断(声明式Pipeline)

假设我们有一个“前端项目发布”流水线,需要根据以下规则控制阶段执行:

  • • main分支触发时,执行生产部署;

  • • main分支(如开发分支)触发时,执行测试验证;

  • • 参数SKIP_TESTtrue时,跳过测试阶段。

示例代码(可直接复制到Jenkins运行):

pipeline {agent anyparameters {booleanParam(name:'SKIP_TEST', defaultValue:false, description:'是否跳过测试?')}stages {// 通用构建阶段stage('代码构建') {steps {echo "🔧 开始构建项目..."echo '模拟:npm install && npm run build'// 伪命令}}// 条件部署阶段stage('生产部署') {when { branch 'main'// 仅 main 分支触发}steps {echo "🚀 触发生产环境部署!"echo '模拟:scp -r dist/* prod-server:/var/www'}}// 条件测试阶段stage('测试验证') {when { allOf { not { branch 'main' } // 非 main 分支expression { params.SKIP_TEST != true } // 未跳过测试}}steps {echo "🧪 执行测试验证..."echo '模拟:npm run test'}}}
}

关键说明

  • • branch 'main':匹配分支名为main的触发;

  • • not { branch 'main' }:反向匹配(非main分支);

  • • allOf:多条件“与”关系(需同时满足);

  • • environment:匹配参数/环境变量值(SKIP_TEST是参数,本质也是环境变量)。

 

不选择跳过测试,执行结果如下

 

 

选择跳过测试,执行结果如下

 

 

🌰 场景2:用script实现复杂逻辑控制(声明式+脚本混合)

假设需要根据“测试用例通过率”动态决定是否继续部署(如通过率>90%才允许上线),这种需要动态计算的场景,script是更合适的选择。

示例代码

pipeline {agent anystages {stage('执行测试') {steps {script {// 模拟测试结果(实际从测试报告解析)def passRate = 95// 假设通过率95%env.TEST_PASS_RATE = passRate.toString()  // 保存到环境变量echo "① 测试完成,通过率:${passRate}%"}}}stage('决定是否部署') {steps {script {if (env.TEST_PASS_RATE.toInteger() > 90) {echo "② 测试通过,准备部署~"// 执行部署操作(示例用echo代替)sh 'echo "开始部署..."'} else {error "③ 测试不通过(通过率仅${env.TEST_PASS_RATE}%),终止流水线!"}}}}}
}

关键说明

  • • script块内使用Groovy语法(如if-else、变量转换);

  • • error函数会直接终止流水线,并标记为失败;

  • • 可结合外部工具(如JUnit测试报告解析)获取真实通过率(需用junit步骤解析报告)。

例如:passRate = 95

 

 

例如:passRate = 85

 

 

🌰 场景3:whenscript的混合使用

如果需要在声明式Pipeline中使用更灵活的条件(如动态计算的布尔值),可以用whenexpression子句调用script块。

示例代码

pipeline {agent anystages {stage('动态条件判断') {when {expression {// 用script动态计算条件(如检查当前时间是否为工作日)def dayOfWeek = new Date().getDay()  // 0=周日,1=周一...6=周六return dayOfWeek >= 1 && dayOfWeek <= 5// 1-5是工作日(周一到周五)}}steps {echo "① 当前是工作日,执行任务~"}}}
}

 

 

三、六大避坑指南 ⚠️
  1. 1. when 时效性问题

    when的条件在流水线启动时解析,无法获取steps中动态生成的环境变量(如测试通过率)。这种情况需用scriptsteps内判断。

    // 错误示范:when 无法获取 steps 生成的变量
    stage('动态变量') {when { environment name: 'DYNAMIC_VAR' } // 永远为 falsesteps { script { env.DYNAMIC_VAR = 'value' } }
    }// 正确方案:改用 script 判断
    stage('动态判断') {steps {script {if (env.DYNAMIC_VAR) { ... }}}
    }
  2. 2. 条件组合技巧

    when仅支持Jenkins预定义的条件(如branchenvironmentexpression),不支持直接写if语句。复杂条件需用allOf(与)、anyOf(或)、not(非)组合。

    when {// AND 关系:需同时满足allOf { branch 'main'environment name: 'DEPLOY_ENV', value: 'prod'}// OR 关系:满足其一anyOf {triggeredBy 'SCMTrigger'triggeredBy 'TimerTrigger'}
    }
  3. 3. 敏感操作保护

    Groovy 脚本中未处理的异常会导致整个流水线立即中断,对于高风险操作(如生产环境部署、数据删除等),需通过异常捕获实现"柔性失败"。

    script {try {sh '高风险命令'} catch (Exception e) {echo "⚠️ 捕获异常: ${e}"currentBuild.result = 'UNSTABLE' // 不中断流水线}
    }
  4. 4. 跳过阶段日志增强

    条件不满足时,when会跳过阶段并在日志中提示Stage skipped,建议添加echo说明原因(如在post阶段记录)。

    post {aborted {echo "⏩ 跳过原因: 分支=${env.BRANCH_NAME}, SKIP_TEST=${params.SKIP_TEST}"}
    }
  5. 5. 参数类型陷阱

    Jenkins 参数在 Groovy 和 Shell 环境中类型不一致

    环境

    布尔参数类型

    数字参数类型

    Groovy (params)

    booleanInteger

    Shell (env)

    StringString
    // 布尔参数需转换比较
    expression { params.SKIP_TEST == true } // 正确
    expression { env.SKIP_TEST == 'true' }  // 错误!
  6. 6. 脚本性能优化

    script块中避免写耗时操作(如循环查询数据库),可能导致流水线卡住。

    // 避免在 script 中执行耗时操作
    script {def result = readFile('report.json') // 小文件可行// 避免:连接数据库查询
    }

四、工具选型速查表
场景推荐方案示例

根据分支/参数跳过阶段

whenbranch 'main'

多条件组合判断

when+allOf/anyOfallOf { branch; environment }

动态计算(如测试通过率)

scriptif (passRate > 90) {...}

调用外部 API 或复杂计算

scriptdef data = httpRequest ...

流程中断控制

scripterror() / currentBuild.result

掌握whenscript的用法后,你可以根据实际需求灵活控制流水线流程,避免无效执行、降低资源消耗~ 

http://www.dtcms.com/a/322895.html

相关文章:

  • 从夯到拉,锐评MC所有武器
  • RK3568笔记九十九:基于FFMPEG拉取RTSP流MPP硬解码视频显示
  • 第5章 Excel公式与函数应用指南(2):数学函数
  • 【C语言】深入探索预处理
  • 系统蓝屏,黑屏,花屏,绿屏,白屏等问题统一解决软件,驱动人生下载
  • SOLi-LABS Page-3 (Stacked injections) --39-53关
  • 在 Vue 中动态引入SVG图标的实现方案
  • spring声明式事务未提交引发的线上问题
  • Vue 3 + TypeScript:深入理解组件引用类型
  • 2025年渗透测试面试题总结-09(题目+回答)
  • 【自动化运维神器Ansible】playbook实践示例:HTTPD安装与卸载全流程解析
  • Blender 快捷键速查表 (Cheat Sheet)
  • 推荐系统学习笔记(十)多目标排序模型
  • “戴着镣铐”的AI推理:中国如何打破算力枷锁,赢得“最后一公里”?
  • Nvidia 开源 KO 驱动学习配置入门
  • 基于51单片机温湿度检测系统无线蓝牙APP上传设计
  • 化工安防误报率↓82%!陌讯多模态融合算法实战解析
  • 【前端八股文面试题】DOM常⻅的操作有哪些?
  • 深入理解对话状态管理:多轮交互中的上下文保持与API最佳实践
  • Linux 中CentOS Stream 8 - yum -y update 异常报错问题
  • 【LLM】Openai之gpt-oss模型和GPT5模型
  • PNPM总结
  • 【SQL进阶】用EXPLAIN看透SQL执行计划:从“盲写“到“精准优化“
  • 如何解决 Vue 项目启动时出现的 “No such module: http_parser” 错误问题
  • AI 边缘计算网关:开启智能新时代的钥匙
  • 爬虫攻防战:反爬与反反爬全解析
  • Node.js特训专栏-实战进阶:22. Docker容器化部署
  • 基于 InfluxDB 的服务器性能监控系统实战(一)
  • 大语言模型提示工程与应用:提示工程-提升模型准确性与减少偏见的方法
  • 【线性代数】线性方程组与矩阵——行列式