Почему dotenv не загружается в Docker, но прекрасно работает на хост-машине? - PullRequest
0 голосов
/ 11 мая 2019

Я хочу создать образ Docker, который будет запускать мое приложение node.js.Я использую пакет dotenv npm для хранения переменных среды..env находится в корне проекта.Когда я запускаю свой скрипт npm, который запускает приложение (npm run start_in_docker) с хост-машины, все работает отлично.Однако, когда я запускаю контейнер Docker, я получаю следующую ошибку:

internal/modules/cjs/loader.js:584
    throw err;
    ^

Error: Cannot find module 'dotenv'
    at Function.Module._resolveFilename (internal/modules/cjs/loader.js:582:15)
    at Function.Module._load (internal/modules/cjs/loader.js:508:25)
    at Module.require (internal/modules/cjs/loader.js:637:17)
    at require (internal/modules/cjs/helpers.js:22:18)
    at Object.<anonymous> (/usr/src/app/src/server/main.js:3:1)
    at Module._compile (internal/modules/cjs/loader.js:701:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:712:10)
    at Module.load (internal/modules/cjs/loader.js:600:32)
    at tryModuleLoad (internal/modules/cjs/loader.js:539:12)
    at Function.Module._load (internal/modules/cjs/loader.js:531:3) 

Это мой Dockerfile:

FROM node:10-alpine

# Create app directory
WORKDIR /usr/src/app

# Install app dependencies
# A wildcard is used to ensure both package.json AND package-lock.json are copied
# where available (npm@5+)
COPY package*.json ./

RUN apk add --update python
RUN apk add --update vim
RUN apk add --update sqlite
RUN npm install --only=production

# Bundle app source
COPY . .

EXPOSE 3000

RUN npm install --unsafe-perm=true sqlite3 -g
RUN npm install pm2 -g
# run node-gyp to build sqlite3
RUN cd /usr/src/app/node_modules/sqlite3 && npm run install
WORKDIR /usr/src/app

Это мой файл docker-compose.yml, который запускает Dockerfile выше:

version: '3'
services:
  appstore-bl-server:
    container_name: appstore-bl-server-production
    build:
      dockerfile: Dockerfile-prod
      context: .
    volumes:
      - ".:/usr/src/app"
    ports:
      - "3000:3000"
    networks:
      - appstore-net
    command: npm run start_in_docker

networks:
  appstore-net:
    driver: bridge

Это мой раздел сценариев package.json:

"scripts": {
    "start_in_docker": "NODE_ENV=development DEBUG=server:*,classes:*,middleware,utils node src/server/main.js",
}

и мне нужно dotenv в моем файле main.js:

require('dotenv').config();

Я попытался указать абсолютный путь в ('dotenv').config(), но он не сработал.Что странно, если я запустил оболочку контейнера (docker run -it myimage /bin/ash), а затем запустил npm run start_in_docker, она также будет работать.dotenv находится в моем пакете.json конечно.

1 Ответ

1 голос
/ 11 мая 2019

Я думаю, это вызвано:

volumes:
  - ".:/usr/src/app"

в вашем файле docker-compose.Это связывает текущий каталог с папкой приложения, то есть заменяется все, включая node_modules.

Попробуйте удалить тома из docker-compose и посмотрите, работает ли он.

При запуске docker run -it myimage /bin/sh он не будет связывать том, то есть будет использовать правильный node_modules, поэтому он работает при этом.

...