我试图在一个node-phash函数中使用aws lambda,但很快就会出现.
我已经找到了node-canvas库here和github的说明,但仍然有一些问题。
我已经采取了以下步骤:
node-phash回购rpath演练的指示,我将env设置为使用node-canvas:
export LDFLAGS=-Wl,-rpath=/var/task/zip for lambda中。npm install,表面上看它很好.node将查看其dep的aws lambda根目录:
$ objdump -p build/ RPATH /pHashBinding.nodegrepRPATHRPATH /var/task/build/Release文件夹,并用Amazon环境中的文件夹覆盖了我的项目的node_modules/phash/build/ReleaseLambda,包括从步骤3到zip根目录的5个*.o文件,以便在/var/task/ in Lambda中解压缩它们不幸的是,在这之后,我仍然会遇到和以前一样的错误:
"errorMessage": "/usr/local/lib64/node-v4.3.x/lib/libstdc++.so.6: version `GLIBCXX_3.4.21' not found (required by /var/task/node_modules/node-phash/build/Release/pHashBinding.node)",
"errorType": "Error",
"stackTrace": [
"Object.Module._extensions..node (module.js:434:18)",
"Module.load (module.js:343:32)",
"Function.Module._load (module.js:300:12)",
"Module.require (module.js:353:17)",
"require (internal/module.js:12:17)",
"Object.<anonymous> (/var/task/node_modules/node-phash/lib/phash.js:23:13)",
"Module._compile (module.js:409:26)",
"Object.Module._extensions..js (module.js:416:10)",
"Module.load (module.js:343:32)"
]
}libstdc++.so.6是我的zip的根。因此,在查找依赖项时,如何让pHashBinding.node引用正确的目录?
发布于 2017-11-02 20:23:31
我知道这是一个更老的问题,但我一直在努力解决这个问题,并设法找到了一个可能对你也有用的解决方案。
这个解决方案来自于这里的GitHub讨论,https://github.com/grpc/grpc/issues/6443#issuecomment-270558452
基本上,当您准备部署到AWS时,应该使用Docker来安装您的软件包。
node_modules文件夹。cd打开到项目文件夹中。docker run --rm -it -v "$PWD":/worker -w /worker node:4.2 npm i --production --silent之后,您应该在项目中看到一个node_modules文件夹,现在可以将其压缩并上传到AWS。
这应该适用于运行npm install时需要本机代码的任何依赖项。
希望这能有所帮助!
https://stackoverflow.com/questions/40967144
复制相似问题