--- title: 'Jenkins 自動化部署' tags: Jenkins disqus: hackmd --- # Jenkins 自動化部署 [TOC] 持續整合、持續交付 (CI/CD) 的觀念在近幾年來越來越被開發人員所重視。透過 CI/CD 概念的實踐,我們可以針對每一次產品的修改,或是週期性地對產品進行各種單元 (unit testing) 或整合測試 (integration testing)。若產品發生狀況,我們可以藉此在第一時間內找出發生問題的最接近位置。同時,我們也可以透過持續整合的工具替我們建置 (build) 服務,並在建置完成後產生報表分析或做自動通知等其他的動作。 而Jenkins就是就是被廣泛使用的工具之一,他同時能提供不同插件來支援不同的專案開發。 此篇是以ios(Xcode)以及gitlab為主。 ## 安裝Jenkins 安裝jenkins有兩種方式: 1. 到[Jenkins](https://www.jenkins.io/)官網下載mac版本的jenkins安裝包並安裝 2. data:image/s3,"s3://crabby-images/97253/972535811da1d93dea848920dfb3e82ad729c7f5" alt="" - 由於jenkins是依賴在Java上,所以需先確保作業系統上是否有安裝Java環境,若無則到[Java環境](https://www.oracle.com/java/technologies/downloads/)下載 data:image/s3,"s3://crabby-images/52788/52788cd03d8d7163f0b8b876fabbe8f08343c08b" alt="" 安裝完畢後,在terminal輸入data:image/s3,"s3://crabby-images/0fd3a/0fd3a90028c62d1945de0fb461bc74c7032d93ba" alt=""來啟動jenkins. 如果是使用 brew install jenkins 則使用以下指令來啟動 ```shell= brew services start jenkins ``` ## Jenkins控制台 當terminal中的jenkins啟動後,即可到預設的[區網](http://localhost:8080)(http://localhost:8080)進入控制控制中心 並照著步驟一步一步進行安裝: ▼ data:image/s3,"s3://crabby-images/bd75e/bd75eac3465afb0ba5c809d588962adc14a60a01" alt="" ▼ data:image/s3,"s3://crabby-images/2170a/2170a516a5b144102f8e4680d4491961eb093415" alt="" 之後應該會進入到這個畫面,但先不用理他。 data:image/s3,"s3://crabby-images/9cd14/9cd14ac82bd77d5b193019dc5b5cfcf54ba9ab27" alt="" 我們先從Dashbaord進入***控制頁*** -> ***管理Jenkins*** -> ***系統設定*** -> ***Jenkins位置***去更變我們的host網址(我目前用本機的ip**http://172.28.15.34:8080/**) ▼ data:image/s3,"s3://crabby-images/e3f2b/e3f2b93327924b073c925d50fc921f6641eb0297" alt="" ▼ data:image/s3,"s3://crabby-images/48165/48165a85e905545421199e2436f763a63e462331" alt="" ▼ data:image/s3,"s3://crabby-images/cced7/cced7ad597ffe5ab764e8c4bb0e4109cc03d8b0f" alt="" 完成後之後進入Jenkins控制台的預設網址就是剛剛設定的網址。 <span style="color:red">如果使用brew安裝的話,可以改port號,但需要多改一個地方</span> 到以下路徑去變更 ```shell= /usr/local/Cellar/jenkins/2.325/homebrew.mxcl.jenkins.plist ``` data:image/s3,"s3://crabby-images/53e30/53e30a647bf37e34c0c4b4c3dfb8d96a35959ec0" alt="image alt" 變更完後記得 restart ``` shell= brew services restart jenkins ``` ## Jenkins外掛套件 Jenkins提供很多不同工具程式的套用(git, gitlab, ruby, xcode等等),因此我們需要去安裝我們專案需要用到的外掛 從***管理Jenkins*** -> ***管理外掛程式*** -> ***可用的去新增***: ▼ data:image/s3,"s3://crabby-images/e3f2b/e3f2b93327924b073c925d50fc921f6641eb0297" alt="" ▼ data:image/s3,"s3://crabby-images/69f5d/69f5d2b3108cc780f55b82c73a7fd7195bce750e" alt="" ▼ data:image/s3,"s3://crabby-images/f5101/f5101b5519e5ff91671c25bf449538d3fd0625c4" alt="" 1. ***xcode integration*** 2. ***gitlab*** 相關全部安裝 3. ***keychains and provisioning profiles management*** 4. ***Slack Notification Plugin*** 進行安裝,(安裝過後可能會需要重新啟動jenkins,這時只需要把預設網址後面加上/restart便會重啟) ## 自動化作業 的以上作業都順利完成後,你便可以開始建立屬於每個專案的自動化作業: 1. 到Dashbaord選擇新增作業 data:image/s3,"s3://crabby-images/2e150/2e150971f90f22a286f3e2426d7bc345af0d9476" alt="" 2. 接著輸入的想要的名稱(做好以專案為主要的名稱,以防混亂)並選擇free-style專案 data:image/s3,"s3://crabby-images/61d8e/61d8e7e2f80d9cc849ddad48abb96e3cc701906b" alt="" - 這裡有兩個選擇(free-style & pipeline),兩種都能實現自動化部屬,但因為在測試的過程中發現Xcode在產生ipa檔案時需要一個名為***ExportOptions.plist***的檔案,裡面包括target的設定、certificates 跟 provisioning profile的資料,而pipe在產出的時候並不會自動生產***ExportOptions.plist***供後續使用,必須要先手動新增或archive才行 - 而free-style則沒這個問題,因為他有更多的設定(proviosioning profile, bitcode, symbols等等),所以在執行的過程就會替整個專案產出一份***ExportOpritons.plist*** 3. 接著會進入作業的設置頁面 ▼ data:image/s3,"s3://crabby-images/0e1c3/0e1c3f99255351cb82ab8b2b9bb2bafa03c3d24e" alt="" 描述舊照自己的意思去填寫 ▼ data:image/s3,"s3://crabby-images/ffed9/ffed96f8a7140388828f4ac07cfa34644dd13f31" alt="" 原始碼管理則將專案網址貼上去 Credentials一開始是沒有的所以必須新增: - 點擊Add - 點Jenkins後會進到這個畫面data:image/s3,"s3://crabby-images/f7d64/f7d6434d448f0b8698827495bac703d7371e6cc0" alt="" 確認一下Kind的位置是"Username with password" 接著在username 跟 password的位置輸入gitlab的帳號密碼 完成後按Add就可以了 - 回的控制頁面,Branches to build則輸入你要build版的Branch(jenkins會依照這條線去拉專案來build),ex: Develop之類的(圖片為測試用先亂填)data:image/s3,"s3://crabby-images/46b36/46b3664680e98dfcb9d7300603ea020300cd81dc" alt="" - 建制觸發程序為notification通知jenkins進行作業的地方,這裏照圖片進行選擇:data:image/s3,"s3://crabby-images/7baf2/7baf2b2d54cd907671cb9ccc9790dcfb703c9367" alt="" 在這層的下面有一個"進階",點開後有兩個地方要設定。 - ***Allowed branches***這邊是要過濾只有哪些branch需要執行jenkins(這邊會有黃色的警告是正常的,不用理會他,他會正常執行。)data:image/s3,"s3://crabby-images/f98cc/f98cc75731e32a0664c328936ce9cd9c412d590e" alt="" - ***Secret token***按"Generate",jenkins便會產生一個token出來,先記著,之後會用到。data:image/s3,"s3://crabby-images/c286f/c286f061d8cb4d381c6ba081d145413a23a0d3ed" alt="" - 接著直接到***Build*** -> ***Xcode*** -> ***General build settings*** -> 右下角有個Setting展開 -> 下移到Configuration的區域後: - ***Scheme***的位置填入xcode專案的scheme名稱data:image/s3,"s3://crabby-images/ebb6d/ebb6d083e692083953946b62ee01f779e1964173" alt="" - ***.ipa filename pattern***則輸入希望產出的ipa檔案名稱,其餘照填。data:image/s3,"s3://crabby-images/1736e/1736e52ea6bead5ff8440a869631cc2f8f6b8786" alt="" ▼打開Code signing & OS X keychain options的 code signing settings: data:image/s3,"s3://crabby-images/eed93/eed939e5edb98e6b0d7d6c37ed74b93ceae4eb14" alt="" - 選擇manual signing - 填入專案使用的provisioning profile的ID以及UUID data:image/s3,"s3://crabby-images/638bf/638bfb9df6e6b36b860a797bc7f8bb81d25bf4d3" alt="" - 將"unclock keychain"勾起來並填入 - 密碼為user密碼data:image/s3,"s3://crabby-images/74fa9/74fa91f662a924783fe8f9ede972b512c0b15496" alt="" ▼打開advanced Xcode build options的advanced build settings: data:image/s3,"s3://crabby-images/9c0b8/9c0b86f0e321546c7b702d87ff526e3bacec12bf" alt="" - ***Custom xcodebuild arguments*** - m1環境要特別設定destination data:image/s3,"s3://crabby-images/48f30/48f30c289e080979e12550751be07b1aea60b083" alt="" ```shell= -allowProvisioningUpdates -destination "generic/platform=iOS" ``` ## Shell Scripts 以上動作都完成後,接下來就是最重要的部分 - 自動化的scriptsdata:image/s3,"s3://crabby-images/76c11/76c11204e1d8f8c09161b717481c667f7d7ab568" alt="" 1. ```shell= xcodebuild -project waninLive.xcodeproj -scheme "waninLive" -sdk iphoneos -configuration Release archive -archivePath "${HOME}/.jenkins/workspace/WaninLive/build/waninLive.xcarchive" ``` - 這段script的作用在透過xcodebuild將project編譯並生產出.xarchive包 - archivePath是目標位置 2. ```shell= xcodebuild -exportArchive -archivePath "${HOME}/.jenkins/workspace/WaninLive/build/waninLive.xcarchive" -exportPath "${HOME}/.jenkins/workspace/WaninLive" -exportOptionsPlist "${HOME}/.jenkins/workspace/WaninLive/ipa/ExportOptions.plist" ``` - 而這段是讓xcodebuild幫我們導出.ipa文件 3. ```shell= xcrun altool --upload-app --type ios -f "${HOME}/.jenkins/workspace/WaninLive/ipa/waninLive.ipa" -u "pacify.triplefeet@gmail.com" -p "yvoq-tmzi-lxoj-lzqd" ``` - 這段則是讓xcode幫我們自動上傳.ipa到testflight上面 - 這裏你會發現後面會有類似帳號密碼的東西,沒錯,-u 後面的參數是apple id,但是後面的 -p 則是一個名叫"app 專用密碼"的東西,他可以讓你再透過apple id使用第三方app時,能夠安全的登入帳號,至於如何生產出這組密碼,請參考[apple 專用密碼](https://support.apple.com/zh-tw/HT204397) ## 設定gitlab trigger 當所有的設置都完成後,便是要跟gitlab做一個綁定,這裏的要求是當主線merge request成功後,jenkins便會觸發自動化部屬: - 先到gitlab的專案頁 -> ***Settings*** -> ***Integrations*** data:image/s3,"s3://crabby-images/545c8/545c829518d4275f4d39ba88fa7e23ddcaf51d1c" alt="" - 將jenkins 剛剛提供的webhook url還有secret token複製貼到integrations 裡的url 跟 secret token的位置 ▼ data:image/s3,"s3://crabby-images/e27a1/e27a1a851a9d81896d543b732df4fd2c3a9214c0" alt="" ▼ data:image/s3,"s3://crabby-images/bca37/bca3718bf4ad31762541cf63311d8bf597a25445" alt="" - 接著選擇你要讓gitlab觸發trigger的條件data:image/s3,"s3://crabby-images/51b86/51b863495a54cbd59c6c81f9524dfb5fb6c5848b" alt="" 這裏是要監聽merge request所以我就勾merge request events 最後在點擊add webhook就成功做綁定了。 --- ## 綁定Slack通知 上面有提到Jenkins有很多額外的外掛功能可以使用,那我們就來實作一個跟slack同步的外掛,目的是當jenkins部屬成功後,會通知slack做一個訊息發布到群組,這樣就可以讓開發者知道部署的進度是否已經完成。 - 首先我們先去Jenkins CI 下載相關的套件: 我們從slack左邊的列表進去**應用程式** data:image/s3,"s3://crabby-images/9c3dc/9c3dcd15b3fdd10a97476cf7b38405bcfb3462e9" alt="" 接著去搜尋**Jenkins CI**並安裝 data:image/s3,"s3://crabby-images/d3eab/d3eab8eb73012bc0957f07a02eee3fdd8c2999d6" alt="" 安裝完畢後輸入目的群組或用戶後點擊***Add Jenkins CI Integrtion*** data:image/s3,"s3://crabby-images/42d1e/42d1e95e27530098f94bf8f7ebd6277bdd5156a4" alt="" - 然後你會進入***slack app directory***的設定台 data:image/s3,"s3://crabby-images/313b3/313b346f1a06dda7c09aafe4e90ba4f92bd9a191" alt="" ***Post to Channel***的選選擇你要發布的頻道,接著下面有一個token,將他複製起來,之後需要這組token data:image/s3,"s3://crabby-images/5b416/5b416496c6fa0e332c3269352dcd92d8d5aa7af3" alt="" - 再來,我們一樣到***管理Jenkins*** -> ***管理外掛程式*** -> ***可用的***搜尋**Slack Notification Plugin**並安裝 data:image/s3,"s3://crabby-images/270ee/270ee35f2cbf4f23465a59a5067b94d9db63854a" alt="" - 接著回到你的作業的**組態**data:image/s3,"s3://crabby-images/4a3cb/4a3cbdad1fa174460b79f64e93a10ee2c9403493" alt="" 你便會回到上面提到的作業列表 - 往下滑你會看到***建置後動作***data:image/s3,"s3://crabby-images/4f14f/4f14f6d3b79878c867cce4f70ed1a789613da6d4" alt="" 並點選***新增建置後動作*** - 這時會有一大堆的選項,請慢慢找到**Slack Notification**並選擇他data:image/s3,"s3://crabby-images/0246f/0246f2bad73aa01620efa0b28a18bf24cd5dec7d" alt="" - 再來你的列表就會出現slack的相關設定data:image/s3,"s3://crabby-images/3ac68/3ac68d9f132ba48c418587a93515d8722247a990" alt="" 這裏就依照個人需求去做設定,但有必須將Workspace和Credential設定好。 - data:image/s3,"s3://crabby-images/130f3/130f3f1f9094ea22400627281ad6e93e96765519" alt="" 將團隊子網域複製到下方圖片的Workspace。 - data:image/s3,"s3://crabby-images/40beb/40beb1c9d557827ae5d99f5ef08cf851313e5056" alt="" - data:image/s3,"s3://crabby-images/a4c55/a4c5598cb31a100aafae1b412edd9394453b8f47" alt="" 這裏你需要創建一個項目為***Secret text***的credential,這是會跟jenkins CI做連線的設定 data:image/s3,"s3://crabby-images/743c8/743c889c352f20008f9ff186daebde6efe5afba3" alt="" Secret的地方就將剛剛從**slack app directory**複製下來的token放進去並儲存 - 再來是***Channel/memebr id***,這裏就填入你的slack通知要通知的群組或是用戶 data:image/s3,"s3://crabby-images/86d80/86d80579fd02bf02b7a2f6e3db574c8a2d5b2228" alt="" 這樣slack notifcation的設定基本上就是完成了~ --- 參考文件: 1. [slack notifcation](https://dotblogs.com.tw/stanley14/2018/05/28/jenkins_slack) 2. [slack 控制台](https://newtalk-workspace.slack.com/apps) 3. [jenkins設定](https://www.jianshu.com/p/3b38582d1a59) 4. [shell scripts指令](https://www.jianshu.com/p/88d9f2e57004)
×
Sign in
Email
Password
Forgot password
or
By clicking below, you agree to our
terms of service
.
Sign in via Facebook
Sign in via Twitter
Sign in via GitHub
Sign in via Dropbox
Sign in with Wallet
Wallet (
)
Connect another wallet
New to HackMD?
Sign up