问题发生在 Jenkins 节点机器为 M1 Mac (Apple Silicon, arm64) 的情况下,构建 iOS App 可能会卡住,目前我遇到的都是卡在 CompileStoryboard 的地方,全网搜了一下也没找到类似的状况。
排查了一下估计有可能是因为调用的 xcodebuild 不是运行的原生 arm64 架构。虽然理论上运行 Rosetta 转译的 x86_64 应用也应该没有问题,但目前最大的可能性就是这个了(因为尝试直接在 M1 Mac mini 节点上面构建是正常的)
目前 Jenkins 在节点上使用的 openjdk 仍然是 x86_64 的,导致 Jenkins 在节点执行任务时的 shell 也是 x86_64 的。
如何判断 Jenkins 是否使用的是 x86_64 架构的 shell:直接在 Terminal 执行 sysctl sysctl.proc_translated
将返回 0 ,在 Rosetta 转译模式下执行会返回 1。
解决方案:
-
方案一:
在构建脚本中,调用 xcodebuild 的时候,加上arch -arm64
前缀,强制使用原生 arm64 的 xcodebuild 来构建 App。
(注意需要判断一下当前是否在 arm64 Mac 上运行,x86_64 Mac 执行此命令会报错,如果你使用的构建脚本是 shell 可以用uname -m
获取当前架构) 方案二:安装原生支持 arm64 架构的 JDK,目前(2021年上半年)仅有 zulu 支持:
brew install --cask zulu
,然后让 Jenkins 使用该 JDK。