使用docker compose运行节点容器时出错

时间:2017-08-13 21:24:23

标签: node.js docker npm docker-compose nodemon

运行“docker-compose up”时,出现以下错误:

npm info lifecycle server@1.0.0~dev: server@1.0.0

> server@1.0.0 dev /code/app
> nodemon -L ./bin/www --exec babel-node

sh: 0: getcwd() failed: No such file or directory
path.js:1144
      cwd = process.cwd();
                    ^

Error: ENOENT: no such file or directory, uv_cwd at Error (native)
at Object.resolve (path.js:1144:25)
at Function.Module._resolveLookupPaths (module.js:361:17)
at Function.Module._resolveFilename (module.js:431:31)
at Function.Module._load (module.js:388:25)
at Module.require (module.js:468:17)
at require (internal/module.js:20:19)
at Object.<anonymous> 
(/usr/local/lib/node_modules/nodemon/bin/nodemon.js:3:11)
at Module._compile (module.js:541:32)
at Object.Module._extensions..js (module.js:550:10)

npm info lifecycle server@1.0.0~dev: Failed to exec dev script
npm ERR! Linux 4.9.36-moby
npm ERR! argv "/usr/local/bin/node" "/usr/local/bin/npm" "run" "dev"
npm ERR! node v6.3.1
npm ERR! npm  v3.10.3
npm ERR! code ELIFECYCLE
npm ERR! server@1.0.0 dev: `nodemon -L ./bin/www --exec babel-node`
npm ERR! Exit status 1
npm ERR! 
npm ERR! Failed at the server@1.0.0 dev script 'nodemon -L ./bin/www --
exec babel-node'.

我的dockerfile如下所示:

FROM joakimbeng/node-zeromq

RUN mkdir /code/
RUN mkdir /code/app/
COPY package.json /code/

WORKDIR /code
RUN npm install -g nodemon babel-cli
RUN npm install

WORKDIR /code/app

CMD ["npm", "run", "dev"]

我的服务是这样的:

node:
    build: ./node/
    ports:
      - "3000:3000"
    volumes:
      - ../code:/code/app
    links:
      - mongodb
      - python
    environment:
      - NODE_ENV=dev
      - NODE_PATH=/code/node_modules
      - MONGODB_ADDRESS=mongodb
      - PYTHON_ADDRESS=python

我试图删除所有容器和图像并再次运行整个过程,但会出现相同的错误。在运行“docker-compose build”时似乎构建正常。

我想在这里完成的是:  1.让容器处理所有依赖项(节点模块)  2.将我的代码库安装到容器中  3.使用nodemon进行热重新加载

2 个答案:

答案 0 :(得分:1)

我最终得到了类似于我最初做的事情。不确定是什么原因造成了我的OP中的错误,但差别似乎是我将我的依赖项挂载到不同的目录中。

Dockerfile:

FROM joakimbeng/node-zeromq

RUN mkdir /code/
RUN mkdir /dependencies/
COPY package.json /dependencies/

WORKDIR /dependencies/
RUN npm install -g nodemon babel-cli
npm install

WORKDIR /code/
CMD bash -c "npm run dev"

docker-compose中的服务:

  node:
build: ./node/
ports:
  - "3000:3000"
volumes:
  - ../code/:/code
links:
  - mongodb
  - python
environment:
  - NODE_ENV=dev
  - NODE_PATH=/dependencies/node_modules
  - MONGODB_ADDRESS=mongodb
  - PYTHON_ADDRESS=python

这样我的依赖项只能在build上安装。

答案 1 :(得分:0)

您的问题是音量分享。从主机到容器共享卷时。如果文件夹已存在于容器中,则主机容器将遮蔽容器文件夹。

如果容器内有10个文件,主机上有0个文件,那么在容量映射后,容器将看到0个文件。因为主机文件夹已挂载且没有任何内容。所以你Dockerfile陈述

RUN npm install

如果主机卷没有完成npm安装,实际上已经消失了。幸运的是,解决方案很简单。您可以将CMD更改为

CMD bash -c "npm install && npm run dev"

如果您不想更改Dockerfile,可以在docker-compose.yml服务的node文件中添加以下内容

command: bash -c "npm install && npm run dev"

编辑(8月14日):

如果您希望您的依赖项在图像中,那么您需要在docker-compose.yml中进行一些更改,您需要的是内部代码单独保留并只链接该目录中的node_modules到你的app目录

node:
    build: ./node/
    ports:
      - "3000:3000"
    volumes:
      - ../code:/code/app
    command: bash -c "ln -fs /code/node_modules /code/app/node_modules && exec npm run dev"
    links:
      - mongodb
      - python
    environment:
      - NODE_ENV=dev
      - NODE_PATH=/code/node_modules
      - MONGODB_ADDRESS=mongodb
      - PYTHON_ADDRESS=python

我注意到的另一点是,您在package.json中运行/code并在运行映像时将代码/code/app置于可能的错误状态。但是根据我上面提到的新编辑,这应该可行