2016-08-23 2 views
0

Мое веб-приложение использует Node.js и MongoDB. Я рисую изображение mongo от . Когда я создаю образ моего узла, приложение работает отлично. Однако, когда я запускаю контейнеры, используя compose, он дает следующую ошибку. Не предполагается ли устанавливать пакеты, когда изображение построено из Dockerfile?Невозможно установить пакет с помощью докера.

web_1 | module.js:457 web_1 | throw err;

web_1 | ^

web_1 |

web_1 | Error: Cannot find module 'mongoose'

web_1 | at Function.Module._resolveFilename (module.js:455:15)

web_1 | at Function.Module._load (module.js:403:25)

web_1 | at Module.require (module.js:483:17)

web_1 | at require (internal/module.js:20:19)

web_1 | at Object. (/worklog/worklog.js:7:14)

web_1 | at Module._compile (module.js:556:32)

web_1 | at Object.Module._extensions..js (module.js:565:10)

web_1 | at Module.load (module.js:473:32)

web_1 | at tryModuleLoad (module.js:432:12)

web_1 | at Function.Module._load (module.js:424:3)

Dockerfile

FROM node 

RUN mkdir -p /worklog 

WORKDIR /worklog 

RUN npm install mongoose \ 
    express \ 
    body-parser \ 
    express-session \ 
    method-override \ 
    connect-mongo \ 
    mongodb 

COPY login.html worklog.html workloglist.html worklog.js /worklog/ 

ENV NODE_VERSION 6.3.1 

EXPOSE 4000 

CMD npm, start 

докер-compose.yml

db: 
    image: mongo 
    ports: 
    - "27017:27017" 
    command: "--smallfiles --logpath=/dev/null" 
web: 
    build: . 
    command: node worklog.js 
    volumes: 
    - .:/worklog 
    ports: 
    - "4000:4000" 
    links: 
    - db 
    environment: 
    PORT: 4000 
+0

Попробуйте "docker-compose rm web && docker-compose rm db && docker-compose build && docker-compose up", чтобы начать с чистой среды. Если вы «docker ps», вы можете увидеть контейнер db_1? – TopperH

+0

Я попробовал, но тот же результат снова. Я видел, что он не вытаскивает пакеты из архива, когда я использую 'docker-compose up' или вашу команду. Да, я вижу, как работает db_1. – emre01

+0

Попробуйте добавить команду докеры-компоновки перед командой сборки. – TopperH

ответ

3

Объемы

volumes: 
    - .:/worklog 

в основном маскирующие все, что установлен в/в Журнал событий сборки с файлы на hos t, включая/worklog/node_modules, если таковые имеются. Вы можете попробовать

volumes: 
    - .:/worklog 
    - /worklog/node_modules 

который я думаю накладки/Журнал событий/node_modules из контейнера в верхней части каталога, установленном с хостом снова делая node_modules видимым для приложения.

+0

Спасибо. Очень четкое объяснение. – emre01

Смежные вопросы