1.什么是pipeline?
在jenkins官方文档是这样介绍pipeline的:Jenkins Pipeline (or simply "Pipeline") is a suite of plugins which supports implementing and integrating continuous delivery pipelinesinto Jenkins.它的意思就是pipeline是一套jenkins官方提供的插件,它可以用来在jenkins中实现和集成连续交付。
下面我就盗用jenkins官方的图的说一下我在实际使用中对pinpeline的理解
如上图所示,这是通过pipeline进行CI/CD的一个简单模型。
我的理解就是;pepeline是一个流程,这个流程定义了完成过一个CI/CD流程的步骤,通过执行这个流程代替手工自动去完成CI/CD,这个流程是由使用者自己定义的。
整个流程主要有以下几个模块组成:
1.agent
2.param
3.stage
首先介绍stage。pipeline实际上就是由很多个stage组成,每个stage完成一件事情。就像上图中第二个stage用来构建项目,第三个stage用来测试项目。所以定义pipeline实际上就是定义多个stage。而stage是由多个step组成,由step来定义这个stage是如何完成一个任务的。比如要执行test这个测试stage,通过step定义第一步拉取代码,第二步进行测试,第三步将测试结果发送邮件。
接着就是agent,agent是用来定义CI/CD流程环境的,比如你在构建gradle项目的时候需要gradle环境,这时候就由agent来定义。agent可以定义全局的,就是所有的stage都会在这个环境中进行,也可以放在stage中,意味这只有该stage会放在这个环境中执行。
然后就是param。param是为整个流程提供参数的。这一点是很好的,比如你使用git进行代码管理,你需要构建某个流程,这时候你只要在构建的时候指定分支参数就可以构建项目。
最后,还有其他部分,比如所有的stage都执行完成了,或者失败了,这时候你需要发送邮件,你可以在最后的部分定义发送邮件,不论构建成功与否。
2.定义pipeline
pipeline的定义被写在一个文本文件——jenkinsfile,该文件又可以提交给项目的源代码控制库, 将pipeline视为应用程序的一部分,以便像任何其他代码一样进行版本控制和审查。
创建Jenkinsfile并将其提交给源代码管理提供了许多直接的好处:
1.自动为所有分支和拉取请求创建pipeline构建过程。
2.pipeline上的代码审查/迭代(以及剩余的源代码)。
3.pipeline的审计跟踪。
4.可由项目的多个成员查看和编辑。
虽然在Web UI直接定义pipelins和使用 Jenkinsfile定义是相同的,但通常认为最佳做法是使用Jenkinsfile定义pipeline并检查其中的源代码控制。
3,为何选择Pipeline?
从根本上说,Jenkins是一个支持多种自动化模式的自动化引擎。Pipeline为Jenkins添加了一套功能强大的自动化工具,支持从简单的持续集成到全面的CD pipeline的用例。通过对一系列相关任务建模,用户可以利用Pipeline的许多功能:
代码:pipeline在代码中实现,通常检查到源代码控制,使团队能够编辑,审查和迭代其交付管道。
持久:pipeline可以在Jenkins master的计划内和计划外重启中存活。
Pausable:在继续pipeline运行之前,pipeline可以选择停止并等待人工输入或批准。
多功能:pipeline支持复杂的实际CD要求,包括并行分叉/连接,循环和执行工作的能力。
可扩展:Pipeline插件支持其DSL的自定义扩展 和多个与其他插件集成的选项。