【问题标题】:Invalid ELF Header - Argon2 package无效的 ELF 标头 - Argon2 包
【发布时间】:2021-11-18 00:13:59
【问题描述】:

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

MacOS Big Sur 11.4 版开发

Image of the error I am getting

我对该错误进行了一些研究,人们说要使用 Docker 编译包,然后发送到 Lambda。在尝试 docker 解决方案之前,我与 Docker 的合作不多,并想探索其他选项。

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

【问题讨论】:

  • 请提供足够的代码,以便其他人更好地理解或重现问题。

标签: node.js amazon-web-services aws-lambda node-modules argon2-ffi


【解决方案1】:

只是添加。要部署到 Lambda,您(最终)需要以 zip 格式发送文件。为了有效地打包你的项目,你需要一个像 Webpack 这样的打包器。问题是,argon2 和任何其他散列实现(如 bcrypt)使用 node-pre-gyp 依赖项,这与 bundler 不兼容。所以选项是:

  • 只需压缩整个项目和 node_modules 中的所有内容。这意味着包括所有未使用但可能很大的东西。
  • 当使用 Webpack 从配置中排除 argon2 时,必须在目标环境中手动安装它。
  • 使用纯 js 版本的 argon2 会慢很多。
  • 如果您使用它来管理密码,则可以将其用于提供安全对称密钥的 AWS KMS 等云服务。然而,这些密钥是加密的,而不是散列的,因此无论好坏,您都可以将密码解密回纯文本。

请记住,哈希性能本身与内存和 CPU 成正比。因此,运行散列算法以获得快速结果可能意味着高昂的 Lambda 费用。

【讨论】:

    【解决方案2】:

    发生了什么事?

    您正在使用的包 (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 在 Mac 上

    谢天谢地,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 的软件包,在这种情况下,您必须选择第一个选项。

    【讨论】:

    • 感谢您提供如此详细的回复并花时间解释正在发生的事情。我尝试了#2并得到了一个错误。 > node-pre-gyp install --fallback-to-build node-pre-gyp ERR!安装响应状态 404 Not Found on github.com/ranisalt/node-argon2/releases/download/v0.28.2/… node-pre-gyp 警告 argon2@0.28.2 和 node@12.0.0 无法安装预构建的二进制文件(node-v72 ABI,未知)(回退到使用节点编译的源代码-gyp) 我正在使用 NVM,我已经尝试过节点 14 和 12。
    • 糟糕,试试npm install --target_arch=x64 --target_platform=linux --target_libc=glibc。错误消息告诉您它无法在该位置找到二进制文件。如果您查看 github.com/ranisalt/node-argon2/releases 的发布页面,您会看到有用于 linux x64 的 glibc 和 musl 版本,您需要选择一个,该命令应该执行此操作。
    • 感谢您的帮助。我最终只是切换到 Bcryptjs 而不是使用 Argon2,这最终解决了我的错误。
    猜你喜欢
    • 2016-11-29
    • 2015-06-14
    • 2023-03-08
    • 1970-01-01
    • 2018-11-29
    • 2012-09-17
    • 2023-03-16
    • 2015-11-13
    • 1970-01-01
    相关资源
    最近更新 更多