如何构建 node-addon-api 与 OS 隔离?

How to build node-addon-api insulated from OS?

我有带有 nodejs 的后端服务器并部署在 heroku 上。

问题是我需要使用一些带有 dll 文件的 fortran-based 程序(64 位和 32 位都存在,并使用 64 位)。

为了处理所有这些问题,我编写了一些 C++ 代码(node-addon-api)。

使用 node-gyp 的 C++ 构建到 .node 文件,并且它在我的本地环境中工作。

但是,它在 heroku 上失败并出现以下错误。

Error: /app/refprop/refpropNapi.node: invalid ELF header

而且我找到了一些关于 ELF header 错误的解释。经过一番搜索,我在下面找到了答案,它似乎完全符合我的情况。

我的 node-addon-api 开发环境是 Windows 10、64 位。 我的假设是 heroku 使用 Linux OS,这就是编译节点文件不起作用的原因。

总之,我有3个问题。

  1. 在Docker上编译C++和dll(我不知道如何在Docker中详细构建)会​​创建可以在heroku上执行的节点吗?

  2. 是否有必要 docker 同时处理后端和 node-addon-api 以确保它们 运行 在同一个 OS 中?

  3. 看来使用docker部署让IaaS更容易,这让我逃避PaaS(heroku),但我没有任何经验。这会是逃离 heroku 的一种方式吗? (我不想再和服务器打交道了,因为我现在工作已经够多了...)

简答:
编译后的 .node 必须与其部署到的特定架构相匹配。在 docker 映像中编译然后部署该 docker 映像是一种方法,但它增加了复杂性,特别是围绕设置、使用和管理 docker 的额外步骤。使用 heroku 的 build 脚本为节点执行此操作的方法不那么复杂。 https://devcenter.heroku.com/changelog-items/1557 and https://devcenter.heroku.com/articles/nodejs-support#customizing-the-build-process

长答案:
这里有更多关于 Heroku 'dyno' 是什么,运行 是 Heroku 应用程序的详细信息,作为背景。 and https://devcenter.heroku.com/articles/how-heroku-works#building-applications

他们用于新应用程序的堆栈列在 https://devcenter.heroku.com/categories/stacks

目前是:

_________________________________________________________________
|Stack Version       | Base Technology | Supported through      |
|Heroku-18 (default) | Ubuntu 18.04    | April 2023             |
|Heroku-16           | Ubuntu 16.04    | April 2021 Learn more  |
|Container           | Docker          | Developer-maintained*  |
_________________________________________________________________

堆栈具有 https://github.com/heroku/heroku-buildpack-nodejs 中描述的节点构建包,用于构建您添加到 heroku 的节点应用程序。

您可以按照 https://devcenter.heroku.com/articles/nodejs-support#customizing-the-build-process 中所述自定义构建过程 https://devcenter.heroku.com/changelog-items/1557 这意味着您可以添加一个构建脚本,每次将您的应用程序添加到 heroku 时,该脚本都会 运行。

"scripts": {
  "start": "node index.js",
  "build": "build steps here to compile your dll on heroku using node-gyp or npm build or npm install"
}

或者您可以使用 heroku-prebuild 或 heroku-postbuild 脚本。

"scripts": {
  "heroku-prebuild": "echo This runs before Heroku installs your dependencies.",
  "heroku-postbuild": "echo This runs afterwards."
}

https://nodejs.org/api/addons.html#addons_building 更详细地描述了如何构建 C++ 插件。

免责声明:我不是 Heroku 员工,最近也没有使用过 Heroku,所以我只是按照公开文档中的描述进行操作。


考虑到您可能想要使用什么来代替 docker 的解释,以下是您列出的问题的答案:

  1. Would compiling C++ and dll on Docker (I don't know how to build in Docker in detail) would create node that can be executed on heroku?

是的。 Heroku 直接支持 docker 容器,或者您可以在匹配 Heroku 使用的 docker 图像(例如 Ubuntu 18.04)上编译并使用编译后的代码。

  1. Would it be NECESSARY to dockerize both backend and node-addon-api to ensure they run in same OS?

如果您使用的是 docker 容器,则后端和 node-addon-api 都需要 运行 在同一个 docker 图像中。如果您只在 docker 上编译,编译后的 C++ 需要匹配最终 运行 上的 OS 节点。

  1. It seems that deploying using docker makes IaaS much easier, which makes me to escape PaaS (heroku), but I don't have any experience. Will it be a way to escape from heroku? (I don't want to work with server more, because I have enough work by now...)

是的。还有其他供应商提供 docker 容器服务,可以 运行 节点服务器。还有其他具有虚拟映像的云提供商可以 运行 节点服务器而无需 docker 化。