Jenkins 2.x的精髓是Pipeline as Code,那爲何要用Pipeline呢?jenkins1.0也能實現自動化構建,但Pipeline可以將之前project中的配置信息以steps的方式放在一個腳本里,將本來獨立運行於單個或者多個節點的任務鏈接起來,實現單個任務難以完成的複雜流程,造成流水式發佈,構建步驟視圖化。簡單來講,Pipeline適用的場景更普遍,能勝任更復雜的發佈流程。舉個例子,job構建工做在master節點,自動化測試腳本在slave節點,這時候jenkins1.0就沒法同時運行兩個節點,而Pipeline能夠。python
1.Pipeline支持兩種語法:Declarative Pipeline(在Pipeline 2.5中引入,結構化方式)和Scripted Pipeline,二者都支持創建連續輸送的Pipeline。
共同點:
二者都是pipeline代碼的持久實現,都可以使用pipeline內置的插件或者插件提供的steps,二者均可以利用共享庫擴展。
區別:
二者不一樣之處在於語法和靈活性。Declarative pipeline對用戶來講,語法更嚴格,有固定的組織結構,更容易生成代碼段,使其成爲用戶更理想的選擇。可是Scripted pipeline更加靈活,由於Groovy自己只能對結構和語法進行限制,對於更復雜的pipeline來講,用戶能夠根據本身的業務進行靈活的實現和擴展。下面介紹中使用Scripted Pipeline語法。android
上圖是以執行git倉庫的腳本文件配置的Pipline腳本,也能夠選擇第一種方式,直接輸入如下腳本也是能夠的git
pipeline{ agent { label 'master' } stages{ stage('安卓程序源碼同步') { steps { sh 'mkdir -p AndroidSampleApp' dir("AndroidSampleApp"){ git branch:'master', url:'https://gitee.com/sfboy/AndroidSampleApp.git' } } } stage('安卓編譯打包') { steps { sh ''' . ~/.bash_profile cd AndroidSampleApp sh gradlew clean assembleDebug ''' } } stage('安卓部署') { steps { sh ''' . ~/.bash_profile cd AndroidSampleApp apk=app/build/outputs/apk/debug/app-debug.apk { #try: 卸載現有的安卓app adb uninstall com.appsflyer.androidsampleapp } || { #catch echo 'no com.appsflyer.androidsampleapp package' } #安裝安卓app adb install $apk ''' } } stage('自動測試程序源碼同步') { steps { sh 'mkdir -p iAppBVT_Python' dir("iAppBVT_Python"){ git branch:'master', url:'https://gitee.com/sfboy/iAppBVT_Python.git' } } } stage('運行自動化測試') { steps { sh ''' . ~/.bash_profile cd iAppBVT_Python #更新python依賴庫 pip3 install -r requirements.txt #運行自動化測試 pytest -sv test/bvt_test.py --tc-file iAppBVT_Python.json --tc-format json ''' } } stage('發佈測試包') { steps { archiveArtifacts artifacts: 'AndroidSampleApp/app/build/outputs/apk/debug/app-debug.apk' } } stage('通知郵件') { steps { emailext body: '$DEFAULT_CONTENT', recipientProviders: [[$class: 'RequesterRecipientProvider']], subject: '$DEFAULT_SUBJECT' } } } }
而後保存便可,Pipline的配置相對仍是比較簡單的,構建結果以下
json
Pipeline能夠很方便實現流水式的持續交付,執行階段經過視圖一目瞭然。更過詳細的資料能夠訪問官方文檔 https://jenkins.io/doc/book/pipeline/bash