使用--mount标志时Docker容器无法运行

时间:2019-06-30 04:08:56

标签: node.js docker volume

我只想创建一个使用found here准则从官方Node.js映像中提取的docker容器。

我要做的唯一更改是我想将主机目录挂载到容器中,以便可以在主机上创建新文件并在容器中更新它们。

我尝试了所有建议here:-v标志,--mount标志等。

但是当我在运行命令中使用这些标志时,实际上没有容器在运行。

我运行以下命令:

docker run -p 49160:8080 -d myname/node-web-app --mount source=/Users/myname/desktop/dockyard/enviro

它吐出一个容器ID:

7302055670c231fb41d04d6475d42405cbee834e37e0827a68d7c396a918d3ec

但是当我运行docker-ps时,容器列表为空。

当我检查docker-ps -a时,可以看到它已退出,代码为9:

CONTAINER ID        IMAGE                          COMMAND                  CREATED             STATUS                         PORTS                    NAMES
dbf7973608a0        myname/node-web-app            "docker-entrypoint.s…"   4 seconds ago       Exited (9) 2 seconds ago                                quirky_sammet

我已经搜索了代码9的解释,但找不到任何内容。

非常感谢可以提供的任何帮助。

UPDATE

已尝试: docker run -p 49160:8080 -d myimage -v /Users/myname/desktop/dockyard/enviro:/usr/src/main

容器退出,代码为0。docker logs仅返回v11.15.0

我知道这意味着容器由于没有进程而退出,但是如果我在没有-v标志的情况下运行docker run -p 49160:8080 -d myimage,则容器运行得很好。

所以不确定为什么-v标志会导致退出(0)。

根据Node.js教程的Dockerfile:

FROM node:11

# Create app directory
WORKDIR /usr/src/main

# 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 npm install
# If you are building your code for production
# RUN npm ci --only=production

# Bundle app source
COPY . .

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

1 个答案:

答案 0 :(得分:1)

在调试时,您可能会发现docker run --interactive --ttydocker run --detach容易。

我认为您的mount语法很烂。我认为您需要sourcetarget,否则Docker引擎不知道容器中目录的映射位置。

我对--mount语法不太熟悉,因此请尝试以下操作将本地目录(/Users/myname/desktop/dockyard/enviro)映射到容器目录(/Users/myname

--volume=/Users/myname/desktop/dockyard/enviro:/Users/myname

退出容器后,您应该可以使用以下方式提取日志:

docker logs dbf7973608a0

更新

您提供的内容应该有效;对我有用。

我在:8080上创建一个简单的Express服务器,并在主机目录中映射到该容器。

创建index.js:

const express = require('express')
const app = express()
const port = 8080

app.get('/', (req, res) => res.send('Happy Birthday Freddie!'))

app.listen(port, () => console.log(`Example app listening on port ${port}!`))

还有package.json:

{
    "name": "test",
    "version": "0.0.1",
    "scripts": {
        "start": "node ./index.js"
    },
    "dependencies": {
        "express": "~4.17.1"
    }
}

然后建造|运行它:

docker build --tag=56822320 .
docker run \
--interactive \
--tty \
--publish=8080:8080 \
--volume=${PWD}:/test \
56822320

它有效:

curl localhost:8080
Happy Birthday Freddie!

为证明该映射有效:

docker run \
--interactive \
--tty \
--publish=8080:8080 \
--volume=${PWD}:/test \
56822320 /bin/sh
# ls /test
Dockerfile  index.js  package.json

HTH!