工具准備
Jenkins 下載地址
JDK 下載地址
題主系統:macOS Mojave 10.15.5
開始安裝
官方文檔:https://www.jenkins.io/zh/doc/book/installing/
Jenkins安裝有兩種方式
第一種是從Jenkins官網下載 .pkg的安裝包,我下載的版本是:jenkins-2.222.4.pkg。但是這種方式安裝的Jenkins目錄是在:/Users/Shared/Jenkins目錄下,而且會創建一個jenkins用戶,當我們打包的時候會出現各種權限不足問題導致打包失敗。
解決方案是修改目錄權限
Finder 前往文件夾:/Users/Shared/Jenkins/Home
修改secrets文件夾訪問權限如下:
或者是遷移了jenkins的目錄來解決權限問題,不推薦使用這種方式安裝。
第二種是使用homebrew安裝,這種方式安裝的目錄在:/Users/mjb/.jenkins,(mjb是我的用戶名)不會出現權限的問。
建議使用第二種方式安裝。
下面詳細介紹下安裝步驟。
homebrew安裝方式
安裝java環境
下載JDK安裝 :https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html
安裝完成,進入下一步安裝homebrew
如果沒有安裝homebrew的話,需要先安裝homebrew
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" mac安裝homebrew失敗怎么辦? 運行下面自動腳本(已經全部替換為國內地址): /bin/zsh -c "$(curl -fsSL https://gitee.com/cunkai/HomebrewCN/raw/master/Homebrew.sh)"
執行命令開始安裝jenkins
安裝最新版本 brew install jenkins 安裝 LTS 版本 brew install jenkins-lts
啟動jenkins可以直接使用下面的命令:
最新版本是 jenkins LTS版本是 Jenkins-lts
注意:這種方式配置的jenkins,需要手動啟動jenkins。
Jenkins安裝完是用瀏覽器直接打開 http://localhost:8080,那么應該是如下的顯示界面
根據頁面提示獲取密碼:打開終端輸入
把顯示的密碼復制粘貼至管理員密碼中,進入自定義jenkins界面
初次使用選擇 安裝推薦的插件

實例配置這里不做修改直接保存
接下里是安裝必要的插件,推薦的插件不夠
系統管理 - > 插件管理 - >可選插件 - > 過濾 - >選擇插件 -> 直接安裝
Xcode integration 必須的 這個是配置Xcode 編譯項的Keychains and Provisioning Profiles Management 證書管理Email Ext Recipients Column Plugin 郵件
CocoaPods Jenkins Integration
GitLab
GitLab Authentication
配置Keychains and Provisioning Profiles Management
cd ~/Library/Keychains
macOS10.12以及以后的系統里面沒有login.keychain文件,只有login.keychain-db,可以復制出來刪除-db,也可以創建一個快捷方式名字叫做login.keychain,upload就好了。(上傳keychain,路徑用自己改名后的那個)

然后添加Provisioning Profiles,上傳方法和上傳login.keychain一樣,去選擇Provisioning Profiles文件,然后upload,然后結果
Provisioning Profiles Directory Path
的是固定格式的/Users/用戶名/Library/MobileDevice/Provisioning\ Profiles/
注 有時候 這個地方 文件夾 會沒有權限
系統設置 配置
Default Subject 【構建通知】: $PROJECT_NAME - Build # $BUILD_NUMBER - $BUILD_STATUS! Default Content <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>${ENV, var="JOB_NAME"}-第${BUILD_NUMBER}次構建日志</title> </head> <body leftmargin="8" marginwidth="0" topmargin="8" marginheight="4" offset="0"> <table width="95%" cellpadding="0" cellspacing="0" style="font-size: 11pt; font-family: Tahoma, Arial, Helvetica, sans-serif"> <tr> <td>各位同事,大家好,以下為${PROJECT_NAME }項目構建信息</td> </tr> <tr> <td><br /> <b><font color="#0B610B">構建信息</font></b> <hr size="2" width="100%" align="center" /></td> </tr> <tr> <td> <ul> <li>項目名稱 : ${PROJECT_NAME}</li> <li>構建編號 : 第${BUILD_NUMBER}次構建</li> <li>觸發原因: ${CHANGES}</li> <li>構建狀態: ${BUILD_STATUS}</li> <li>構建日志: <a href="${BUILD_URL}console">${BUILD_URL}console</a></li> <li>構建 Url : <a href="${BUILD_URL}">${BUILD_URL}</a></li> <li>工作目錄 : <a href="${PROJECT_URL}ws">${PROJECT_URL}ws</a></li> <li>項目 Url : <a href="${PROJECT_URL}">${PROJECT_URL}</a></li> </ul> </td> </tr> </table> </body> </html>
開始配置任務
然后創建一個任務,創建了兩個任務上傳蒲公英 和 testTestflight 。
可以選擇保留版本 時間 和 個數 這里 其實 選 丟棄舊的構建
這里填上git 地址 分支
Build Triggers
觸發構建的方式
其實輪詢 就行 檢查到有新的 改動 才會打包
這里可以任意勾選 執行步驟 例如 其實因為個推 bug 和 修改build 號的需求 且 需要pod install 就選了 先執行 shell 腳本 (這個腳本需要按照自己項目來寫)
pod install --verbose --no-repo-update buildMainPlist="/Users/xiexing/.jenkins/workspace/app/MarkDaily/Info.plist" buildServicePlist="/Users/xiexing/.jenkins/workspace/app/NotificationService/Info.plist" buildNumber=$(date +"%m%d%H%M") /usr/libexec/PlistBuddy -c "Set :CFBundleVersion $buildNumber" "$buildMainPlist" /usr/libexec/PlistBuddy -c "Set :CFBundleVersion $buildNumber" "$buildServicePlist"
選擇 Xcode 插件
接下來 就是xcode 的配置 自行選擇就可
配置:
Configuration :Release
Xcode Schema :File
注 $workspace 這里是因為 那個 蒲公英插件(他不能識別文件夾) 才這樣 寫
Testflight 的 就可以寫
這一項記得勾選
Build就完成設置了
接下里 就到 上傳了
蒲公英 可以查看
https://www.pgyer.com/doc/view/jenkins_ios 配置
Testflight 選擇shell 腳本上傳
最后添加一個shell 腳本就行
ALTOOLPATH=/Applications/Xcode.app/Contents/Applications/Application\ Loader.app/Contents/Frameworks/ITunesSoftwareService.framework/Versions/A/Support/altool IPAPATH="/Users/xiexing/.jenkins/workspace/APP-TESTFLIGHT/build/XXXX.ipa" APPID="XXXX" APPPASSWORD="XXX" "${ALTOOLPATH}" --validate-app -f "${IPAPATH}" -u "${APPID}" -p "${APPPASSWORD}" --output-format xml "${ALTOOLPATH}" --upload-app -f "${IPAPATH}" -u "${APPID}" -p "${APPPASSWORD}" --output-format xml
最后一步 發送郵件
這里其實 就是采用 我們在設置 上 填好的 Project Recipient List:$DEFAULT_RECIPIENTS $DEFAULT_REPLYTO Project Reply-To List:$DEFAULT_REPLYTO $DEFAULT_RECIPIENTS Content Type:Html Default Subject:$DEFAULT_SUBJECT Testflight Default Content :$DEFAULT_CONTENT
最后點擊 保存
兩個任務 只有build 和 上傳 不一樣 其他統一
可以先手動構建一下 看看成不成功
詳細文檔查看:https://www.jianshu.com/p/cfa42d187c49
https://www.jianshu.com/p/cb188b8033ad