无效的 ELF 标头 - Argon2 包

Mic*_*emy 3 amazon-web-services node.js node-modules aws-lambda argon2-ffi

我遇到一个错误,提示名为“argon2”的包的“无效的 ELF 标头”。通过无服务器框架将我的代码上传到 AWS Lambda 时。代码在本地运行时完美运行。

MacOS Big Sur 版本 11.4 上的开发

我收到的错误的图片

我对这个错误进行了一些研究,人们说使用 Docker 来编译包,然后发送到 Lambda。我没有太多使用 Docker,并且想在尝试 docker 解决方案之前探索其他选项。

任何指导或帮助将不胜感激!我已经被这个错误困扰了一两天了。

Dan*_*ies 9

到底是怎么回事?

您正在使用的包 ( argon2) 包含与 argon2 算法的 C 实现的绑定。换句话说,包本身包装了一个用 C 编写的库,并使其可以在您的 Node.js 环境中访问。

该 C 包也随您的包一起提供,并在您运行npm install argon2. 这意味着安装 argon2 后,您的文件系统上有一个二进制共享库,它与您的节点环境连接。由于您是在 MacOS 上安装,因此将为 Mac 编译(或下载)二进制文件。这意味着您最终会得到 MACH-O 文件(这是 macOS 的可执行文件格式)而不是 ELF 文件(这是 Linux 用于可执行文件的格式)。

现在,您的 Lambda(在底层运行 Linux)实际上会抱怨您在 Mac 上构建的可执行文件不是 Linux 可执行文件。

你如何解决这个问题?

简而言之,您需要一种方法来npm install构建或下载适用于 Linux 的 argon2 版本。有两种不同的方法可以实现此目的。选一个:

  1. npm install在Linux上

正如标题所说,在 Linux 下下载并构建您的依赖项。您可以使用虚拟机或 Docker 容器来执行此操作。另一种选择是使用 AWS 构建 SaaS 产品 (AWS CodeBuild) 来执行此操作。

  1. npm install --target_arch=x64 --target_platform=linux --target_libc=glibc在苹果电脑上

值得庆幸的是 argon2 支持 node-pre-gyp。它们有效地为您提供了预构建的二进制文件,这意味着您只需拉取 Linux 二进制文件即可,而不必自己编译它们。为此,请丢弃您的 node_modules 文件夹并运行npm install --target_arch=x64 --target_platform=linux. 这将下载 Linux 文件,而不是 macOS 文件。然后你可以将所有内容推入你的 lambda 中。请注意,这意味着您的应用程序将不再在本地运行,因为您的 Mac 无法运行 Linux 可执行文件(您必须npm install再次运行,省略这两个参数才能返回 MacOS 版本)。

请注意,除了 argon2 之外,可能还有一些软件包不支持 MacOS,在这种情况下,您必须选择第一个选项。