跳转到主要内容

Apple Silicon 支持

·3 分钟阅读

随着 Apple Silicon 硬件将在今年晚些时候发布,您该如何让自己的 Electron 应用在新硬件上运行呢?


随着 Electron 11.0.0-beta.1 的发布,Electron 团队现在正在发布可在 Apple 新的 Apple Silicon 硬件上运行的 Electron 版本,Apple 计划在今年晚些时候推出这些硬件。您可以通过 npm install electron@beta 获取最新测试版,或直接从我们的发布网站下载。

它是如何运作的?

从 Electron 11 开始,我们将为 Intel Mac 和 Apple Silicon Mac 发布单独的 Electron 版本。在此更改之前,我们已经发布了两个工件:darwin-x64mas-x64,后者用于 Mac App Store 兼容性。现在,我们正在发布另外两个工件:darwin-arm64mas-arm64,它们是上述工件的 Apple Silicon 等效版本。

我需要做什么?

您需要发布两个版本的应用程序:一个用于 x64 (Intel Mac),一个用于 arm64 (Apple Silicon)。好消息是 electron-packagerelectron-rebuildelectron-forge 已经支持以 arm64 架构为目标。只要您运行的是这些软件包的最新版本,一旦您将目标架构更新为 arm64,您的应用程序就应该能完美运行。

将来,我们将发布一个包,允许您将 arm64x64 应用程序“合并”为一个通用二进制文件,但值得注意的是,这个二进制文件将会非常大,可能不适合分发给用户。

更新:该包现已在 @electron/universal 上提供。您可以用它来将两个已打包的 x64 和 arm64 应用合并成一个单一的二进制文件。

潜在问题

原生模块

由于您要面向一个新的架构,您需要更新一些依赖项,这可能会导致构建问题。下面列出了一些依赖项的最低版本要求,供您参考。

依赖项版本要求
Xcode>=12.2.0
node-gyp>=7.1.0
electron-rebuild>=1.12.0
electron-packager>=15.1.0

由于这些依赖项的版本要求,您可能需要修复或更新某些原生模块。值得注意的是,Xcode 升级会引入新版本的 macOS SDK,这可能会导致您的原生模块构建失败。

我该如何测试?

目前,Apple Silicon 应用程序只能在 Apple Silicon 硬件上运行,而撰写此博客文章时,该硬件尚未商用。如果您有 开发者过渡套件,您可以在其上测试您的应用程序。否则,您将不得不等待生产型 Apple Silicon 硬件的发布,才能测试您的应用程序是否正常工作。

Rosetta 2 怎么样?

Rosetta 2 是 Apple Rosetta 技术的最新迭代,它允许您在新 arm64 Apple Silicon 硬件上运行 x64 Intel 应用程序。尽管我们相信 x64 Electron 应用程序将在 Rosetta 2 下运行,但仍有一些重要事项需要注意(以及您应该发布原生 arm64 二进制文件的原因)。

  • 您的应用程序性能将显著降低。Electron / V8 使用 JIT 编译 JavaScript,并且由于 Rosetta 的工作方式,您将有效地运行两次 JIT(一次在 V8 中,一次在 Rosetta 中)。
  • 您将失去 Apple Silicon 中新技术带来的好处,例如更大的内存页大小。
  • 我们有没有提到过性能会显著下降?