解决 Jenkins M1 Mac (arm64) 节点构建 iOS / macOS App 时 CompileStoryboard 卡住的问题

解决 Jenkins M1 Mac (arm64) 节点构建 iOS / macOS App 时 CompileStoryboard 卡住的问题

问题发生在 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。

    解决 Jenkins M1 Mac (arm64) 节点构建 iOS / macOS App 时 CompileStoryboard 卡住的问题_第1张图片
    (注意需要判断一下当前是否在 arm64 Mac 上运行,x86_64 Mac 执行此命令会报错,如果你使用的构建脚本是 shell 可以用 uname -m 获取当前架构)

  • 方案二:安装原生支持 arm64 架构的 JDK,目前(2021年上半年)仅有 zulu 支持: brew install --cask zulu,将 JAVA_HOME 配置为该 zulu JDK,并在 Jenkins 的 node 管理配置中重新连接此节点,成功后将如下图所示。 解决 Jenkins M1 Mac (arm64) 节点构建 iOS / macOS App 时 CompileStoryboard 卡住的问题_第2张图片

你可能感兴趣的:(iOS,Objective-C,iOS,Jenkins,macOS,Xcode,CI)