美文网首页CI/CDJenkins
Jenkins-iOS自动化构建及相关问题

Jenkins-iOS自动化构建及相关问题

作者: yuyangkk | 来源:发表于2021-08-05 10:38 被阅读0次

    前言

    为了方便测试打包,提高速度,我们在一台新的机器部署Jenkins,前两年虽然已经做过一次Jenkins的安装以及自动化,但是已经时隔三年,Jenkins也在不断的更新,这次安装部署过程中,还是遇见了不少问题的,下面是我的在部署Jenkins过程中的一些记录。

    安装方式

    之前安装Jenkins,我使用的是.pkg文件,在Jenkins官网中选择稳定版(LTS)或者开发版,但是目前官方在MacOS上推荐是用Homebrew进行安装。
    使用brew以下方式安装:
    最新版本

    //安装
    brew install jenkins
    //启动服务
    brew services start jenkins
    //重启服务
    brew services restart jenkins
    //更新服务
    brew upgrade jenkins
    

    LTS 版本

    //安装
    brew install jenkins-lts
    //启动服务
    brew services start jenkins-lts
    //重启服务
    brew services restart jenkins-lts
    //更新服务
    brew upgrade jenkins-lts
    

    开启服务

    我选择的是最新版本,在终端执行brew install jenkins等待片刻,安装完成使用命令brew services start jenkins开启Jenkins服务。
    浏览器中输入127.0.0.1:8080,进入Jenkins页面,具体可参考iOS Jenkins自动化打包

    • 输入密码
    • 安装推荐插件
    • 创建管理员账户(如果不创建,就是admin,密码就是安装时的解锁密码)
    • ....
    • 完成

    配置局域网内访问

    找到下面的路径,修改homebrew.mxcl.jenkins.plist修改其文件中的--httpListenAddress=x.x.x.x,其中x.x.x.x是你本机的ip地址,这样在同一局域网下的别的机器就可以直接访问Jenkins了。

    /usr/local/opt/jenkins/homebrew.mxcl.jenkins.plist
    
    修改远程访问地址.png

    安装插件

    请注意,这里是和文章iOS Jenkins自动化打包不太一致,这里没有安装Keychains and Provisioning Profiles Management插件,因为这个插件在出现了无法上传keychain 和 profile文件的问题

    0-1添加插件.png 0-2安装Xcode插件.png

    添加Job

    1-0创建job.png

    项目配置

    1. General

    1-2General-丢弃构建.png

    2. 参数化构建

    这里可以配置你任何想参数化的环境变量,比如分支、比如Debug或者Release。。。。

    1-3参数化构建.png

    3. 源码管理

    2-0源码管理.png 2-1添加凭证.png

    4. 配置CocoaPods脚本

    #!/bin/bash -ilex
    export LANG=en_US.UTF-8
    export LANGUAGE=en_US.UTF-8
    export LC_ALL=en_US.UTF-8
    
    pod install
    echo "======pod 完成"
    
    
    

    5. 构建- 重中之重

    添加Xcode构建步骤

    5-1增加构建步骤-Xcode.png 5-2添加Development Team ID.png 5-3Xcode构建setting.png 5-4构建-PackApplication.png 5-5设置keychian路径.png 5-6Advanced Xcode Build options.png

    截止到目前,应该是可以进行打包了,并且导出ipa了。

    上传fim

    在构建中添加shell脚本

    #读取登录信息
    #!/bin/bash --login
    #!/bin/bash -l
    #fir.im 具体可以查看 https://fir.im/docs/publish
    filePath=`ls ~/Desktop/qiangungun-package/ios/*.ipa`
    apiToken=`curl -X "POST" "https://api.jappstore.com/apps" -H "Content-Type: application/json" -d "{\"type\":\"ios\",\"bundle_id\":\"应用的bundle id\",\"api_token\":\"在fim申请的apiToken\"}"`
    
    #接收返回结果,并且使用jq解析出来key、token、上传的地址
    echo $apiToken > /tmp/result.json
    key=`cat /tmp/result.json |jq -r '.cert.binary.key'`
    token=`cat /tmp/result.json |jq -r '.cert.binary.token'`
    upload_url=`cat /tmp/result.json |jq -r '.cert.binary.upload_url'`
    buildVersion=`echo $RANDOM`
    #curl命令上传文件到fir.im
    /usr/bin/curl -k -F "key=$key" -F "token=$token" -F "file=@$filePath" -F "x:name=中欧财富-ios-new" -F "x:version=$APP_Version" -F "x:build=指定的App版本,可参数化" -F "x:release_type=Adhoc" -F "x:changelog=更新日志可参数化" $upload_url  --http1.1 #https://up.qbox.me
    
    rm -rf $filePath
    echo "=======上传完成"
    

    问题

    问题1:仓库连接失败,请查看是否需要连接VPN
    error-无仓库权限.png
    问题2:jq解析失败
    error-jq-command-not-found.png

    解决方案:brew install jq

    问题3:pod:commend not found
    error-pod-command-not-found.png

    解决方案:查看cocoapods是否安装,如果已经安装,并在脚本头部加上#!/bin/bash -ilex

    问题4:上传fir SSL_connect: SSL_ERROR_SYSCALL in connection to up.qbox.me:443
    image.png

    导致这个错误的原因,就是up.qbox.me访问不了,这个地址哪来的呢?是fim官方提供的上传脚本里面,最后一个参数

    image.png

    解决方案:将这个地址换成我们上传fim那一步中,从fim接口中返回的upload_url

    问题5 上传fir curl: (92) HTTP/2 stream 0 was not closed cleanly: PROTOCOL_ERROR (err 1)
    curl错误

    在上传fir中的curl命令中,添加--http1.1指定HTTP版本

    有问题,欢迎留言

    相关文章

      网友评论

        本文标题:Jenkins-iOS自动化构建及相关问题

        本文链接:https://www.haomeiwen.com/subject/mgmjvltx.html