Docker Compose不绑定端口

rot*_*erd 7 docker fig docker-compose

我的容器有以下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
Run Code Online (Sandbox Code Playgroud)

我构建这个容器并启动图像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
Run Code Online (Sandbox Code Playgroud)

当我现在运行时,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": []
},
Run Code Online (Sandbox Code Playgroud)

Ole*_*evs 8

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

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

  1. ...

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

解决这个问题的一种方法是使用up而不是run:

构建,(重新)创建,启动和附加到服务的容器.

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

运行命令并启用服务端口并映射到主机.

PS尝试编辑原始答案,遭到拒绝,两次.保持优雅,所以.


Kev*_*ist 4

这是故意行为fig run

对服务运行一次性命令。

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

来源

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