我正在使用 docker compose 执行两个 docker 容器。
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
eef95ca1b59b gogent_qaf "/bin/sh -c ./slave.s" 14 seconds ago Up 12 seconds 4242/tcp, 7000-7005/tcp, 9999/tcp, 0.0.0.0:30022->22/tcp coreqafidm_qaf_1
a01373e893eb gogent_master "/bin/sh -c ./master." 15 seconds ago Up 13 seconds 4242/tcp, 0.0.0.0:27000->7000/tcp, 0.0.0.0:27001->7001/tcp, 0.0.0.0:27002->7002/tcp, 0.0.0.0:27003->7003/tcp, 0.0.0.0:29999->9999/tcp coreqafidm_master_1
当我尝试使用时:
docker exec -it coreqafidm_qaf_1 /bin/bash
我收到错误:
docker exec -it coreqafidm_qaf_1 /bin/bash
no such file or directory
这是 docker-compose 文件:
version: '2'
services:
master:
image: gogent_master
volumes:
- .:/d1/apps/qaf
- ./../core-idm-gogent/:/d1/apps/gogent
ports:
- "27000-27003:7000-7003"
- "29999:9999"
build:
context: .
dockerfile: Dockerfile.master
qaf:
image: gogent_qaf
ports:
- "30022:22"
volumes:
- .:/d1/apps/qaf
- ./../core-idm-gogent/:/d1/apps/gogent
depends_on: [master]
build:
context: .
dockerfile: Dockerfile.qaf
涉及的两个 Docker 文件都有最后一个 WORKDIR 命令:
WORKDIR /d1/apps/qaf
如果机器的自然文件系统上有一个 REAL 目录/d1/apps/qaf ,则 docker exec 在某种程度上可以工作。它将打开一个外壳。但是,映射的卷对此 shell 不可用,并且我看到的文件是真实的自然目录中的文件,而不是应该映射的卷。
$ mkdir /d1/apps/qaf
$ docker exec -it coreqafidm_qaf_1 /bin/bash
root@eef95ca1b59b:/d1/apps/qaf#
root@eef95ca1b59b:/d1/apps/qaf# ls /d1/apps/gogent
ls: cannot access /d1/apps/gogent: No such file or directory
卷在 docker-compose 上下文中正常工作。我在其中执行脚本并且它们可以工作。只是 docker exec 无法看到卷。
最佳答案
嗯,我在另一台机器上安装了 docker-compose 等,并且不存在这个问题。去搞清楚。这只是我没有时间追查的事情之一。
关于docker exec 无法在 docker-compose 容器中工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35560171/