Skip to content

Compatibility zh CN

ArchiBot edited this page Apr 16, 2022 · 65 revisions

兼容性

ASF 是一个用 C# 语言编写并运行在 .NET 平台上的应用程序。 这意味着 ASF 并非直接被编译为可供 CPU 执行的​机器码,而是被编译为 CIL,一种需要相应的运行环境才能执行的语言。

This approach has gigantic amount of advantages, as CIL is platform-independent, which is why ASF can run natively on many available OSes, especially Windows, Linux and macOS. There is not only no emulation needed, but also support for all platform-related and hardware-related optimizations, such as CPU SSE instructions. 基于此,ASF 在表现出卓越的性能以及优化的同时,仍然能提供完美的兼容性和可靠性。

这也意味着运行 ASF 没有特定的操作系统要求,因为它需要的只是运行于操作系统上的运行环境而非操作系统本身。 As long as that runtime is executing ASF code properly, it does not matter whether underlying OS is Windows, Linux, macOS, BSD, Sony Playstation 4, Nintendo Wii or your toaster - as long as there is .NET for it, there is ASF for it.

但是,无论您想要在哪个平台上运行 ASF,您必须确保该平台安装了 .NET 的依赖项。 这些都是确保运行环境功能正常的底层库,也是确保 ASF 能够第一时间工作的绝对核心。 通常情况下,部分库(甚至全部)很有可能已经安装在系统内。


ASF 打包

ASF 有两种主要的打包方式——Generic 包以及 OS-specific 包(操作系统包)。 从功能上来讲,这两种包是完全一样的,都能够自动进行更新。 唯一的区别就是 Generic 包中不包含 OS-specific 包内所具有的能使 ASF 运行的环境。


Generic

Generic 包是一个与平台无关的版本,所以它不包含特定于计算机的代码。 所以使用这个包需要您的操作系统中已经安装有合适版本的 .NET 运行时环境。 我们都知道保证依赖始终是最新的这件事是十分令人烦恼的,所以这个包主要面向那些已经在使用 .NET,不想为了 ASF 对已有环境做单独复制的人。 Generic 包还允许您将 ASF 运行在任何可以获得正常工作的 .NET 环境的机器上,不需要担心是否存在相应的 OS-specific 包。

对于一般用户甚至是高级用户,如果只是想要运行 ASF 而不想要深入了解 . NET 的技术细节,不推荐使用 Generic 包。 也就是说,如果您明白以上所讲的内容,那您就可以使用它,不然下面所介绍的 OS-specific 包才是最合适的。

.NET 框架包

除了上面提到的 Generic 包,我们也提供 Generic-netf 包,它基于 .NET 框架而非 .NET(Core)。 该包是一种旧式包,它补全了如今缺少的 ASF V2 时代的兼容性,并且可以使用 Mono 运行,而来自 .NET 的 Generic 包则无法用于 Mono。

通常,您应该尽量避免使用此程序包,因为大多数操作系统都完全(并且更好地)支持上面提到的 Generic 包。 事实上,这个软件包只适用于缺乏 .NET 运行时环境,但能够运行 Mono 的平台。 此类平台包括 linux-x86(32 位 i386/i686 Linux),以及 linux-armel(Raspberry Pi 0 & 1 等开发板所用的 ARMv6),目前官方尚未提供这些平台可用的 .NET 运行时环境。

随着时间的推移,.NET 会支持更多平台,而 .NET Framework 和 .NET 之间会更加不兼容,Generic-netf 包将会在未来完全被 Generic 包取代。 如果您可以使用任何 .NET 软件包,就不要使用框架包,因为 Generic-netf 与 .NET 版本相比缺少许多功能和兼容性,并且功能会随着时间的推移变少。 我们对无法使用 Generic 包的平台提供此版本的支持(例如 linux-x86),并且也仅基于最新版本的运行时环境(例如最新版 Mono)提供支持。


OS-specific(特定操作系统)

除了 Generic 包中包含的托管代码之外,OS-specific 包还包括指定平台的本机代码。 换句话说,OS-specific 包内部已经包含了可用的 .NET 运行时环境,使您可以跳过麻烦的安装过程,直接启动 ASF。 OS-specific 包,顾名思义,是针对不同操作系统的,每种操作系统都需要其特定的版本——例如 Windows 需要 PE32+ ArchiSteamFarm.exe 二进制文件,而 Linux 则需要 Unix ELF ArchiSteamFarm 二进制文件。 您可能知道,这两种类型之间是完全不兼容的。

ASF 目前提供以下几种 OS-specific 包:

  • linux-arm,支持 32 位基于 ARM(ARMv7+)的 GNU/Linux 操作系统。 包括所有支持当前和未来版本 GNU/Linux 操作系统(例如 Raspberry Pi OS)的平台,例如 Raspberry Pi 2(或更新版本)。 此包支持更早的 ARM 架构,例如 Raspberry Pi 0 & 1 使用的 ARMv6,也不支持未实现所需 GNU/Linux 环境的操作系统(例如 Android)。
  • linux-arm64,支持 64 位基于 ARM(ARMv8+)的 GNU/Linux 操作系统。 包括所有支持当前和未来版本 AArch64 GNU/Linux 操作系统(例如 Debian)的平台,例如 Raspberry Pi 3(或更新版本)。 此包支持 32 位操作系统(例如 Raspberry Pi OS),因为它们缺少所需的 64 位库,也不支持未实现所需 GNU/Linux 环境的操作系统(例如 Android)。
  • linux-x64 支持 64 位 GNU/Linux 操作系统。 包括 Alpine、CentOS/Fedora/RHEL、Debian/Ubuntu、OpenSUSE/SLES 等很多操作系统以及它们的衍生版的当前和未来版本。
  • osx-arm64 works on 64-bit ARM-based (Apple silicon) macOS OSes. 包括 11 及更新版本。
  • osx-x64 works on 64-bit macOS OSes. 包括 10.15 及更新版本。
  • win-x64,支持 64 位 Windows 操作系统。 包括 Windows 8.1、10、11、Server 2012+ 以及未来的版本。 Windows 7 需要安装 Generic 包,并且对其支持非常有限,您在此系统下运行 ASF 可能会遇到问题。 我们强烈建议您尽快更新,因为将来版本的 ASF 可能会完全不能在此系统运行,更不用说这个操作系统已经在 2020 年寿终正寝。

当然,即使没有适合您操作系统及架构的 OS-specific 包,您也可以手动安装适当的 .NET 运行时环境并运行 Generic ASF 包,这也是这个包存在的主要原因。 Generic ASF 包与平台无关,可在任何具有可用 .NET 运行时环境的平台上运行。 需要注意——ASF 需要的是 .NET 运行时环境,而不是特定的操作系统或架构。 例如,如果您使用的是 32 位 Windows,但 ASF 没有 win-x86 版本,您仍然可以安装 win-x86 版本的 .NET SDK,然后运行 Generic 版本的 ASF。 我们无法为所有操作系统和架构组合都生成一份可执行文件,所以我们为此画下一道分隔线。 x86 就是这条线之一,因为这种架构自 2004 年开始就过时了。

您可以访问​发行说明​查看完整的 .NET 6.0 支持的平台与操作系统列表。


运行时环境需求

如果您正在使用 OS-specific 包,那么您不必担心运行时需求,因为 ASF 总会将所需的最新运行时环境打包在一起,只要您已安装并更新 .NET 依赖项,就能够正常运行。 换句话说,您不需要安装 .NET 运行时环境或 SDK,因为 OS-specific 版本只需要本机已安装对应操作系统的依赖项,而不需要其他项目。

但如果您使用 Generic 包,则必须保证已安装 ASF 所需的对应平台的 .NET 运行时环境。

ASF 目前指向的构建目标是 .NET 6.0net6.0),但在未来可能会指向更高版本。 net6.0 自 6.0.100 SDK(6.0.0 运行时环境)以来就受到支持,但 ASF 被配置为偏好编译时最新版本的运行时环境,所以您应该确保您的机器上有​最新版 SDK(或至少有运行时环境)。 如果您的运行时环境版本低于编译时的最低支持版本,Generic ASF 包将会拒绝启动。

如有疑问,您可以访问我们用于编译并在 GitHub 上部署新版本的 CI。 您可以在每个构建中看到 dotnet --info 的输出,用于验证 .NET。

Clone this wiki locally