Jenkins
官方文档地址:https://jenkins.io/doc/pipeline/steps/workflow-basic-steps/
概述
Jenkins的管道化插件对于其用户来说是个改革。依赖于域领域语言(DSL)Groovy,管道化插件实现了脚本化
Groovy是一种基于JVM(Java虚拟机)的敏捷开发语言,它结合了Python、Ruby和Smalltalk的许多强大的特性
随着管道插件的引入,用户现在可以在Jenkinsfile中实现一个项目的整个构建/测试/部署管道,并将其存储在他们的代码旁边,将他们的管道作为另一段代码检查到源代码控制中。
这个管道插件的灵感来自于构建流插件,但它的目标是改进构建流所探索的一些概念,例如:
有能力暂停/恢复执行工作。
检查管道定义到源代码控制(Jenkinsfile)
支持用额外的组织spe扩展领域特定语言
Jenkins从根本上讲是一种支持多种自动化模式的自动化引擎。Pipeline在Jenkins上添加了一套强大的自动化工具,支持从简单的连续集成到全面的连续输送Pipeline的用例。通过建模一系列相关任务,用户可以利用Pipeline 的许多功能:
代码:Pipeline以代码的形式实现,通常被检入源代码控制,使团队能够编辑,审查和迭代其传送流程。
耐用:Pipeline可以在计划和计划外重新启动Jenkins管理时同时存在。
Pausable:Pipeline可以选择停止并等待人工输入或批准,然后再继续Pipeline运行。
]多功能:Pipeline支持复杂的现实世界连续交付要求,包括并行分叉/连接,循环和执行工作的能力。
可扩展:Pipeline插件支持其DSL的自定义扩展 以及与其他插件集成的多个选项。
参数/词汇说明
Jenkinsfile的管道配置官网地址:https://jenkins.io/doc/pipeline/steps/workflow-basic-steps/
credentiaiId : jenkins中对应的应用市场证书
readfile :从工作区读取文件;
writeFile:向工作区写入文件;
retry :重复执行最多N次
Step :一般构建步骤;
Dir :更改当前目录;
Def :定义变量;
Sh : 执行;
sed的替换命令格式:s/A/B/g 或者s#A#B#g 或者s_A_B_g
如:sh 'sed -i \'s#${gdmp_ws_name}#gdmp-ws-develop#g\'lab/mainsite/gdmp-ws-SVC.yaml' ;把svc文件中的{gdmp_ws_name} 替换成gdmp-ws-develop;
Stage: 一个Pipeline可以划分为若干个Stage,每个Stage代表一组操作。注意,Stage是一个逻辑分组的概念,可以跨多个Node。
Node:一个Node就是一个Jenkins节点,或者是Master,或者是Agent,是执行Step的具体运行期环境。
Step:
Step是最基本的操作单元,小到创建一个目录,大到构建一个Docker镜像,由各类Jenkins Plugin提供。
Jenkinsfile:
Pipeline的定义文件,由Stage,Node,Step组成,一般存放于代码库根目录下。
执行步骤(参考jenkins的控制台进行进行说明)
Pipeline
Pipeline的视觉展现
Pipeline例子:
1.在任何可用的代理上执行此管道或其任何阶段。
2.定义了“构建”阶段。
3.执行与“构建”阶段相关的一些步骤。
4.定义了“测试”阶段。
5.执行与“测试”阶段相关的一些步骤。
6.定义了“部署”阶段。
7.执行与“部署”阶段相关的一些步骤。
1.pipeline 是声明式的管道特有的语法,它定义了一个“块”,其中包含了执行整个管道的所有内容和指令。
2.agent 是声明式的管道专用语法,它指示Jenkins分配一个遗嘱执行人(在一个节点上)和整个管道的工作区。
3.stage 是描述这条管道的一个阶段的语法块。
4.steps 是声明式的管道特定的语法,它描述了在这个阶段将要运行的步骤。
5.sh 是一个管道步骤(由管道提供的:节点和进程插件)执行给定的shell命令。
6.junit 是另一个管道步骤(由JUnit插件提供)用于聚合测试报告。
node 是脚本化的管道专用语法,它指示Jenkins在任何可用的代理/节点上执行此管道。(以及其中包含的任何阶段)。这实际上相当于声明式管道特定语法中的代理。
一. Step:
单一任务,从基础中告诉了Jenkins应该怎么做。例如,要执行shell命令,请make使用以下sh步骤:sh
'make'。当插件扩展Pipeline DSL时,通常意味着插件已经实现了一个新的步骤。
二. Node:
Pipeline执行中的大部分工作都是在一个或多个声明node步骤的上下文中完成的。将工作限制在Node步骤中有两件事情:
通过将项目添加到Jenkins队列来调度要运行的块中包含的步骤。一旦执行器在节点上空闲,步骤就会运行。
创建工作区(特定于该特定Pipeline的目录),可以从源代码控制中检出的文件完成工作。
根据您的Jenkins配置,某些工作空间在一段时间不活动后可能无法自动清除。
三.Stage:
stage是定义整个Pipeline的概念上不同子集的一个步骤,例如:“Build”,“Test”和“Deploy”,许多插件用于可视化或呈现Jenkins Pipeline状态/进度。
且Pipeline Stage View插件可以将管道中的一个个段进行可视化: