解决 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。

    xcodebuild

    (注意需要判断一下当前是否在 arm64 Mac 上运行,x86_64 Mac 执行此命令会报错,如果你使用的构建脚本是 shell 可以用 uname -m 获取当前架构)

  • 方案二:安装原生支持 arm64 架构的 JDK,目前(2021年上半年)仅有 zulu 支持: brew install --cask zulu,然后让 Jenkins 使用该 JDK。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容