前段時間公司重構了一個flutter專案,自動化打包用的是Jenkins,在這過程中頁遇到了一些坑,藉此寫一篇文章來,讓大家少走些彎路。 先看一下打包完成的效果圖:
data:image/s3,"s3://crabby-images/a2cc7/a2cc79292bf33b06f3fd6980e616c2b883d6c98d" alt="image.png"
- iOS需要單獨配一臺Mac來進行打包,因為需要Xcode,Docker是沒有Xcode環境
- android最好也放在這臺Mac上打包,因為你要用Docker的話會遇到檔案讀寫許可權的問題
- 搭建Flutter開發環境
- 確保本地能打包成功,本地打包請參考iOS,Android
Jenkins環境配置
1. 安裝 JRE環境
Jenkins 執行依賴於java環境 ,沒有安裝的請去官網自行下載安裝
2. 安裝 Jenkins
千萬別用官網下載的pkg包進行安裝,它會預設將 Jenkins安裝在/Users/Shared目錄下,在打包的時候會遇到許可權問題, 所以強烈建議大家用brew來安裝Jenkins.
-
安裝Jenkins
brew install jenkins
-
命令列啟動Jenkins
java -jar /usr/local/Cellar/jenkins/${你的Jenkins版本}/libexec/jenkins.war --httpPort=8080 或 Jenkins 複製程式碼
-
開啟瀏覽器,輸入 localhost:8080 就可看到Jenkins的web介面
-
Jenkins開機啟動
命令列安裝的jenkins不自備開機啟動功能,每次重啟後都要命令列執行啟動,非常麻煩,使用以下步驟可以在每次開機後自動拉起一個jenkins的命令列。
-
建立開機啟動指令碼 jenkinsBoot.sh
-
加入啟動jenkins程式碼
-
設定指令碼許可權
sudo chmod 777 xxxx/jenkinsBoot.sh
-
設定指令碼開啟方式
-
設定指令碼引用,使指令碼可執行
chmod +x xxxx/jenkinsBoot.sh
-
加入使用者的登入項
-
重新啟動計算機,會發現自動執行了jenkinsBoot.sh這個指令碼。
-
3. Jenkins配置
第一次開啟Jenkins時需要解鎖Jenkins,你看到的頁面是這樣的
data:image/s3,"s3://crabby-images/70682/706820aa04ae204508910af64d1219df3f4771d1" alt="image.png"
進入紅色字型路徑下將密碼拷貝到輸入框,點選continue
然後點選左側一個模組進入下載頁面,時間可能會很久,耐心等待
data:image/s3,"s3://crabby-images/53674/53674a8aeebd6d9930beac2b082773079f3d1481" alt="image.png"
data:image/s3,"s3://crabby-images/167e6/167e605d44dd853ef5ff48c1917cf1c28fa942b7" alt="image.png"
自定義設定使用者名稱及密碼,點選儲存並完成按鈕,進入下圖頁面。
data:image/s3,"s3://crabby-images/22a8b/22a8bf9d7e6faba08bb545cd4b13b1c04540c305" alt="image.png"
- Keychains and Provisioning Profiles Management(iOS證照管理)
- Xcode integration(iOS專用)
- Gradle plugin(Android專用)
- description setter plugin(根據構建日誌檔案的RegEx,設定每個構建的描述。比如fir的上傳地址)
4. 專案工程配置
iOS
- 新建專案
data:image/s3,"s3://crabby-images/016e1/016e16e13db7f3f965de8a3b00ab54740669225f" alt="image.png"
- 專案構建配置
data:image/s3,"s3://crabby-images/11e9b/11e9b996900c31286ec8f1e5bdb50cdca61e05be" alt="image.png"
打包型別(注意:AdHoc需要在你專案中配置configuration,自行google)
data:image/s3,"s3://crabby-images/b4689/b4689be1ce97f74441ddadac1de0183152f60b9f" alt="image.png"
打包分支
data:image/s3,"s3://crabby-images/49b74/49b7481338ce4c07003c9f18051afdeccb13a803" alt="image.png"
原始碼管理
data:image/s3,"s3://crabby-images/c28d7/c28d7739745a2770ab07cdbede80a53631cea83a" alt="image.png"
SSH私鑰新增
data:image/s3,"s3://crabby-images/55c50/55c508108f64306acf2bed247f14b45a133d514c" alt="image.png"
證照和描述檔案配置
data:image/s3,"s3://crabby-images/86003/86003acad2f420519b081d1fb8ae0c2ea539c898" alt="image.png"
data:image/s3,"s3://crabby-images/c1206/c1206a665a7b581123e2b573ff9106911a933348" alt="image.png"
iOS證照和描述檔案首先要在系統管理->Keychains and Provisioning Profiles Management中設定和上傳後才能在你的專案中選擇新增,iOS證照和描述檔案的製作我就不多說了,自行Google
data:image/s3,"s3://crabby-images/99b94/99b949df0e436cdf5b4e6192466255276511acbe" alt="image.png"
這裡的login.keychain檔案可能需要自己copy到桌面並改下檔案字尾,因為它是隱藏檔案
data:image/s3,"s3://crabby-images/dd1f6/dd1f67fcc31cdf7588cb36300ac734d973f4feff" alt="image.png"
這裡的描述檔案都要上傳,其實路徑就可以寫/Users/xxxx/Library/MobileDevice/Provisioning Profiles路徑,這是Xcode儲存描述檔案的路徑,上傳的時候也可以去這個路徑下去上傳
data:image/s3,"s3://crabby-images/23571/2357107c8fdb62341c2b91b30d7fb12b6dbddafb" alt="image.png"
一切準備好後就可以在專案配置中選擇證照和描述檔案了,這時我們第一次add keychain可能不能去選擇Code Signing Identity,需要我們儲存一下後就能選擇了
data:image/s3,"s3://crabby-images/a543f/a543f8be4dda47c57b582c4633f38b7c729661e4" alt="image.png"
data:image/s3,"s3://crabby-images/10d09/10d09d52c12ed9ddf00af1945d5a399e5d618b03" alt="image.png"
在這裡我們使用shell指令碼來構建,以便我們構建完成能夠上傳到fir上。
data:image/s3,"s3://crabby-images/7b6bf/7b6bff215d0cc9a4b36420835536e6ea80020eb2" alt="Flutter Jenkins打包"
指令碼程式碼
security set-key-partition-list -S apple-tool:,apple: -s -k "開機密碼" ~/Library/Keychains/login.keychain-db
#假設指令碼放置在與專案相同的路徑下
project_path=$(pwd)
# flutter環境變數設定
export PUB_HOSTED_URL=https://pub.flutter-io.cn
export FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn
export PATH=/Users/yongjianhe/flutter/bin:$PATH
flutter build ios
cd $project_path/ios
#取當前時間字串新增到檔案結尾
now=$(date +"%Y_%m_%d_%H:%M")
#指定專案的scheme名稱
scheme="Runner"
#指定要打包的配置名
configuration=${BUILD_TYPE}
#指定打包所使用的輸出方式,目前支援app-store, package, ad-hoc, enterprise, development, 和developer-id,即xcodebuild的method引數
if [ $BUILD_TYPE == "Release" ]
then
export_method="app-store"
elif [ $BUILD_TYPE == "AdHoc" ]
then
export_method="ad-hoc"
else
export_method="development"
fi
#指定專案地址
workspace_path="${project_path}/ios/Runner.xcodeproj"
#指定輸出路徑
rm -rf "${project_path}/ipa"
mkdir -p "${project_path}/ipa"
output_path="${project_path}/ipa"
#指定輸出歸檔檔案地址
archive_path="$output_path/zaihui_crm_${export_method}_${now}.xcarchive"
#指定輸出ipa地址
ipa_path="$output_path/zaihui_crm_${BUILD_TYPE}_${BUILD_BRANCH}_${BUILD_REPOSITORY}_${now}.ipa"
#指定輸出ipa名稱
ipa_name="zaihui_crm_${BUILD_TYPE}_${BUILD_BRANCH}_${now}.ipa"
commit_msg="$1"
#輸出設定的變數值
echo "===workspace path: ${workspace_path}==="
echo "===archive path: ${archive_path}==="
echo "===ipa path: ${ipa_path}==="
echo "===export method: ${export_method}==="
echo "===commit msg: $1==="
#先清空前一次build
fastlane gym --scheme ${scheme} --clean --configuration ${configuration} --archive_path ${archive_path} --export_method ${export_method} --output_directory ${output_path} --output_name ${ipa_name}
#上傳到fir
if [ ${export_method} != "app-store" ]
then
fir publish ${ipa_path} -T "fir API token" -c $commit_msg
fi
複製程式碼
因為我使用的是fastlane指令打包的,所以打包的電腦需要安裝fastlane
這裡有個地方需要注意的點就是當出現打包失敗是由於執行flutter指令碼錯誤造成的時候,這個原因可能是你當前的flutter版本執行flutter build iOS時,在Generated.xcconfig中並沒有生成FLUTTER_BUILD_MODE引數,這個是執行flutter指令碼所需要的引數,不過沒事,你只需要在你的工程檔案再新增一個指令碼就行了。
data:image/s3,"s3://crabby-images/5893a/5893aa38a64932b4dffdb45f546cca706df98212" alt="image.png"
最後還要在你的工程中設定描述檔案(製作相應環境的描述檔案,下載並開啟,debug對應開發證照,adhoc和release對應生產證照),到了這裡大家可能有個疑問,就是前面我都上傳了證照了,為什麼這裡還要填寫,原因是前面上傳的證照只是為了儲存Code Signing Identity以便在login.keychain去訪問他,而不是去儲存它,我想描述檔案也同樣如此,所以我們需要設定描述檔案的路徑
data:image/s3,"s3://crabby-images/229e0/229e03810ced68959e8e97406786c6118663695d" alt="image.png"
構建名稱設定工程名+打包模式+分支名
data:image/s3,"s3://crabby-images/c970c/c970ce202df7395e7e409f5b3e7e32ec669ad5e3" alt="image.png"
想要成功顯示fir地址,先要設定Html
data:image/s3,"s3://crabby-images/6b79d/6b79dd9abfea65f033dd66c6b2ce917a92c06963" alt="WechatIMG4650.jpeg"
data:image/s3,"s3://crabby-images/b84cb/b84cb0eed06ea23f3b19c7d397c17066e4efa185" alt="image.png"
這時候你就能打出iOS包了
Android
安卓打包相對於iOS來說就簡單很多了
- 新建專案
- 專案構建配置
如果大家在iOS證照和描述檔案以及安卓上有其它問題,可以參考一下以下兩篇文章:
本文版權屬於再惠研發團隊,歡迎轉載,轉載請保留出處。@xqqlv