繁体   English   中英

找不到在 docker compose 环境中运行的节点 js 应用程序的模块

[英]Cannot find module for a node js app running in a docker compose environment

对于我的新手问题,我感到很抱歉,但是我在解决这个错误时遇到了糟糕的一天,我有一个 Express 应用程序,我正在尝试在 docker compose 中运行它。 我用过这个 Dockerfile:

FROM mhart/alpine-node
RUN mkdir -p /usr/src/app
RUN chmod -R 777 /usr/src/app
WORKDIR /usr/src/app
RUN npm install node-gyp -g
RUN npm install nodemon -g
ENV NODE_ENV development
EXPOSE 3000

我的 docker-compose 文件的这一部分:

backend:
    mem_limit: 100m
    build:
      context: .
      dockerfile: dockerfiles/node/Dockerfile
    command: npm start
    depends_on:
      - mongo
      - elasticsearch
    volumes:
      - ./backend/:/usr/src/app
    ports:
      - 3000:3000
    links:
      - "mongo:mongo"
      - "elasticsearch:elasticsearch"

当我做 docker-compose up 时,我得到这个错误:

backend_1        | npm info it worked if it ends with ok
backend_1        | npm info using npm@3.10.10
backend_1        | npm info using node@v6.9.5
backend_1        | npm info lifecycle service-designer@1.0.0~prestart: service-designer@1.0.0
backend_1        | npm info lifecycle service-designer@1.0.0~start: service-designer@1.0.0
backend_1        | 
backend_1        | > service-designer@1.0.0 start /usr/src/app
backend_1        | > nodemon index.js
backend_1        | 
backend_1        | [nodemon] 1.11.0
backend_1        | [nodemon] to restart at any time, enter `rs`
backend_1        | [nodemon] watching: *.*
backend_1        | [nodemon] starting `node index.js`
backend_1        | module.js:471
backend_1        |     throw err;
backend_1        |     ^
backend_1        | 
backend_1        | Error: Cannot find module 'dotenv'
backend_1        |     at Function.Module._resolveFilename (module.js:469:15)
backend_1        |     at Function.Module._load (module.js:417:25)
backend_1        |     at Module.require (module.js:497:17)
backend_1        |     at require (internal/module.js:20:19)
backend_1        |     at Object.<anonymous> (/usr/src/app/index.js:1:63)
backend_1        |     at Module._compile (module.js:570:32)
backend_1        |     at Object.Module._extensions..js (module.js:579:10)
backend_1        |     at Module.load (module.js:487:32)
backend_1        |     at tryModuleLoad (module.js:446:12)
backend_1        |     at Function.Module._load (module.js:438:3)
backend_1        | [nodemon] app crashed - waiting for file changes before starting...

如果我在后端容器中执行ls -al ,我会得到后端应用程序文件夹内容的完整列表,但听起来 node_modules 依赖项无法识别。

您需要在容器中安装依赖项,而 Dockerfile 中缺少这些依赖项。

常见的方法是创建一个已经知道您的应用程序的 Dockerfile,并使其复制您的package.json文件并执行npm install

这允许您的容器在您以后运行应用程序时找到所有代码依赖项。

请参阅此处的示例: https ://nodejs.org/en/docs/guides/nodejs-docker-webapp/

示例Dockerfile

FROM node:boron

# Create app directory
RUN mkdir -p /usr/src/app
WORKDIR /usr/src/app

# Install app dependencies
COPY package.json /usr/src/app/
RUN npm install

# Bundle app source
COPY . /usr/src/app

EXPOSE 8080
CMD [ "npm", "start" ]

当然,您可能需要调整COPY命令的路径。

如果您的Dockerfilepackage.json文件是正确的并且仍然存在问题:

  1. 确保您已重建容器映像。

  2. 尝试

docker-compose down -v

在使用docker-compose up再次启动容器之前。

这将删除所有卷。

当我运行docker-compose up时,我也遇到了同样的问题。

通过运行docker-compose up --build而不是docker-compose up解决了问题。

npm install添加到 Dockerfile 后,将 node_modules 添加到卷

volumes:
      - ./backend/:/usr/src/app
      - /usr/src/app/node_modules

它发生在我身上,因为我的文件名是大写的。

建议将文件重命名为小写

删除 dist 文件夹

再次运行

npm run start:dev

生成一个新的 dist 文件夹。

再次运行

docker build -t <name> .

如果你的 Dockerfiles 和 compose 文件是正确的,那么你应该这样做 docker docker-compose build --no-cache然后你可以再次做docker-compose up 这为我解决了这个问题。

我有同样的问题,你需要做的只是运行npm i来安装所有依赖项,然后重建,问题解决了

确保在scripts对象的package.json中, npm start具有 nodemon 命令来运行您的应用程序

示例:如果您的应用程序由server.js文件提供服务

"scripts": {
    "start": "nodemon server.js",
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM