MongoDBClient加密的节点映像编译错误

2024-10-01 22:36:17 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在使用带有node:12.18.3-alpine映像的Docker。我将mongodb-client-encryption添加到package.json中,但当我在映像内安装包时,会出现错误。一切都在node:12.18.3图像上运行。除了python、g++和make之外,我还需要安装其他东西吗?我创建了最小复制:

Package.json:

{
  "name": "MONG-ENCRPT-TEST",
  "version": "1.0.0",
  "main": "index.js",
  "license": "MIT",
  "dependencies": {
    "mongodb-client-encryption": "^1.1.0"
  }
}

这是我的Dockerfile:

FROM node:12.18.3-alpine

WORKDIR /user/app

COPY package.json .
COPY yarn.lock .

RUN apk update && apk add python g++ make && rm -rf /var/cache/apk/*
RUN yarn

CMD echo ok

docker-compose.yml:

version: '3.8'
services:
  api-test-mongo:
    restart: unless-stopped
    build:
      context: ./
      dockerfile: ./Dockerfile
    command: echo ok

这是运行docker compose up后的错误:

[5/5] Building fresh packages...
error /user/app/node_modules/mongodb-client-encryption: Command failed.
Exit code: 1
Command: prebuild-install --tag-prefix node-v || node-gyp rebuild
Arguments:
Directory: /user/app/node_modules/mongodb-client-encryption
Output:
prebuild-install WARN install No prebuilt binaries found (target=12.18.3 runtime=node arch=x64 libc=musl platform=linux)
gyp info it worked if it ends with ok
gyp info using node-gyp@5.1.1
gyp info using node@12.18.3 | linux | x64
gyp info find Python using Python version 2.7.18 found at "/usr/bin/python"
gyp http GET https://unofficial-builds.nodejs.org/download/release/v12.18.3/node-v12.18.3-headers.tar.gz
gyp http 200 https://unofficial-builds.nodejs.org/download/release/v12.18.3/node-v12.18.3-headers.tar.gz
gyp http GET https://unofficial-builds.nodejs.org/download/release/v12.18.3/SHASUMS256.txt
gyp http 200 https://unofficial-builds.nodejs.org/download/release/v12.18.3/SHASUMS256.txt
gyp info spawn /usr/bin/python
gyp info spawn args [
gyp info spawn args   '/user/app/node_modules/node-gyp/gyp/gyp_main.py',
gyp info spawn args   'binding.gyp',
gyp info spawn args   '-f',
gyp info spawn args   'make',
gyp info spawn args   '-I',
gyp info spawn args   '/user/app/node_modules/mongodb-client-encryption/build/config.gypi',
gyp info spawn args   '-I',
gyp info spawn args   '/user/app/node_modules/node-gyp/addon.gypi',
gyp info spawn args   '-I',
gyp info spawn args   '/root/.cache/node-gyp/12.18.3/include/node/common.gypi',
gyp info spawn args   '-Dlibrary=shared_library',
gyp info spawn args   '-Dvisibility=default',
gyp info spawn args   '-Dnode_root_dir=/root/.cache/node-gyp/12.18.3',
gyp info spawn args   '-Dnode_gyp_dir=/user/app/node_modules/node-gyp',
gyp info spawn args   '-Dnode_lib_file=/root/.cache/node-gyp/12.18.3/<(target_arch)/node.lib',
gyp info spawn args   '-Dmodule_root_dir=/user/app/node_modules/mongodb-client-encryption',
gyp info spawn args   '-Dnode_engine=v8',
gyp info spawn args   '--depth=.',
gyp info spawn args   '--no-parallel',
gyp info spawn args   '--generator-output',
gyp info spawn args   'build',
gyp info spawn args   '-Goutput_dir=.'
gyp info spawn args ]
gyp info spawn make
gyp info spawn args [ 'BUILDTYPE=Release', '-C', 'build' ]
make: Entering directory '/user/app/node_modules/mongodb-client-encryption/build'
  CXX(target) Release/obj.target/mongocrypt/src/mongocrypt.o
In file included from ../src/mongocrypt.cc:1:
../src/mongocrypt.h:8:10: fatal error: mongocrypt/mongocrypt.h: No such file or directory
    8 | #include <mongocrypt/mongocrypt.h>
      |          ^~~~~~~~~~~~~~~~~~~~~~~~~
compilation terminated.
make: *** [mongocrypt.target.mk:113: Release/obj.target/mongocrypt/src/mongocrypt.o] Error 1
make: Leaving directory '/user/app/node_modules/mongodb-client-encryption/build'
gyp ERR! build error
gyp ERR! stack Error: `make` failed with exit code: 2
gyp ERR! stack     at ChildProcess.onExit (/user/app/node_modules/node-gyp/lib/build.js:194:23)
gyp ERR! stack     at ChildProcess.emit (events.js:315:20)
gyp ERR! stack     at Process.ChildProcess._handle.onexit (internal/child_process.js:275:12)
gyp ERR! System Linux 4.19.76-linuxkit
gyp ERR! command "/usr/local/bin/node" "/user/app/node_modules/.bin/node-gyp" "rebuild"
gyp ERR! cwd /user/app/node_modules/mongodb-client-encryption
gyp ERR! node -v v12.18.3
gyp ERR! node-gyp -v v5.1.1
gyp ERR! not ok

Tags: buildinfoclientmodulesnodeappmakemongodb
2条回答

我所做的工作不是修补我的NODE版本或mongo-client-encryption

当使用节点v14时,不会出现错误。 对我来说,NODE 16的更新破坏了Linux和Mac上的一切

我做了什么来修复它:从我的pakcage.json中删除mongo-client-encryption,并将其作为外部添加到您的webpack配置中,让webpack处理它

// webpack.config.js
module.exports = {
  ...
  externals: ["mongodb-client-encryption"]
}

与package.json一起使用:

"dependencies": {
  ...
  "mongoose": "5.11.15",
  "mongoose-auto-increment": "5.0.1",
},

参考资料:

在package.json中"mongodb-client-encryption": "1.2.1"时Docker构建成功

更高版本的NODEJS,尝试使用最新版本的mongodb-client-encryption

相关问题 更多 >

    热门问题