7

我的容器有以下 Dockerfile:

FROM        centos:centos7

# Install software
RUN         yum -y update && yum clean all
RUN         yum install -y tar gzip wget && yum clean all

# Install io.js
RUN         mkdir /root/iojs
RUN         wget https://iojs.org/dist/v1.1.0/iojs-v1.1.0-linux-x64.tar.gz
RUN         tar -zxvf iojs-v1.1.0-linux-x64.tar.gz -C /root/iojs
RUN         rm -f iojs-v1.1.0-linux-x64.tar.gz

# add io.js to path
RUN         echo "PATH=$PATH:/root/iojs/iojs-v1.1.0-linux-x64/bin" >> /root/.bashrc

# go to /src
WORKDIR     /src

CMD         /bin/bash

我构建了这个容器并使用docker run -i -t -p 8080:8080 -v /srv/source:/usr/src/app -w /usr/src/app --rm iojs-dev bash. Docker 将端口 8080 绑定到主机端口 8080,这样我就可以从我的客户端访问 iojs-application。一切正常。

现在我想用 docker-compose 启动我的容器,使用下面的 docker-compose.yml

webfrontend:
    image: iojs-dev
    links:
        - db
    command: bash -c "iojs test.js"
    ports:
        - "127.0.0.1:8080:8080"
    volumes:
        - /srv/source:/usr/src/app
        - /logs:/logs
db:
    image: mariadb
    environment:
        MYSQL_ROOT_PASSWORD: 12345

当我现在运行时,docker-compose run webfrontend bash我无法访问主机上的 8080 端口。没有绑定端口。的结果为空,并且端口设置docker ports的结果也为空:docker inspect

"NetworkSettings": {
    "Bridge": "docker0",
    "Gateway": "172.17.42.1",
    "IPAddress": "172.17.0.51",
    "IPPrefixLen": 16,
    "MacAddress": "02:42:ac:11:00:33",
    "PortMapping": null,
    "Ports": {
        "8080/tcp": null
    }
},
"HostConfig": {
    "Binds": [
        "/srv/source:/usr/src/app:rw",
        "/logs:/logs:rw"
    ],
    "CapAdd": null,
    "CapDrop": null,
    "ContainerIDFile": "",
    "Devices": null,
    "Dns": null,
    "DnsSearch": null,
    "ExtraHosts": null,
    "Links": [
        "/docker_db_1:/docker_webfrontend_run_34/db",
        "/docker_db_1:/docker_webfrontend_run_34/db_1",
        "/docker_db_1:/docker_webfrontend_run_34/docker_db_1"
    ],
    "LxcConf": null,
    "NetworkMode": "bridge",
    "PortBindings": null,
    "Privileged": false,
    "PublishAllPorts": false,
    "RestartPolicy": {
        "MaximumRetryCount": 0,
        "Name": ""
    },
    "SecurityOpt": null,
    "VolumesFrom": []
},
4

2 回答 2

10

docker-compose run根据文档,这是故意的行为:

使用时run,与正常调出容器有两点不同:

  1. ...

  2. 默认情况下,不会创建任何端口,以防它们与已打开的端口发生冲突。

克服这个问题的一种方法是使用up而不是run,它:

为服务构建、(重新)创建、启动和附加到容器。

如果您使用的是 1.1.0 或更高版本,另一种方法是传递--service-ports选项:

在启用服务端口并映射到主机的情况下运行命令。

PS尝试编辑原始答案,被拒绝了两次。保持优雅,所以。

于 2015-04-30T08:55:01.077 回答
4

这是故意的行为fig run

在服务上运行一次性命令。

一次性命令在具有与该服务的普通容器相同的配置的新容器中启动,因此卷、链接等都将按预期创建。与普通容器唯一不同的是该命令将被指定的命令覆盖,并且不会创建端口以防它们发生冲突

来源

fig up可能是您正在寻找的命令,它将(重新)根据您的 fig.yml 创建所有容器并启动它们。

于 2015-02-16T08:06:12.317 回答