我正在使用macOS 10.12上的Docker1.12.5,并使用它来设置一个开发环境,我有一个应用程序映像和一个共享的redis映像,其中包含一些预先填充的配置变量。
即使在阅读了一些教程(以及如何在Mac上无法使用docker0 )之后,我仍然很难连接这两个容器。
我使用以下方法启动我的redis映像:
docker run -d -p 6379:6379 (IMAGE ID)在我的redis图像中,我有:
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
dffb89854618 d59 "docker-entrypoint.sh" 20 seconds ago Up 19 seconds 0.0.0.0:6379->6379/tcp drunk_williams和从我的Mac,我可以成功地连接通过redis-cli命令,没有问题。
然而,当我启动一个简单的ubuntu映像时,我似乎无法连接到这个单独的redis映像:
root@2d4eda315f4f:/# ifconfig
eth0 Link encap:Ethernet HWaddr 02:42:ac:11:00:03
inet addr:172.17.0.3 Bcast:0.0.0.0 Mask:255.255.0.0
inet6 addr: fe80::42:acff:fe11:3/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:20707 errors:0 dropped:0 overruns:0 frame:0
TX packets:11515 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:28252929 (28.2 MB) TX bytes:635848 (635.8 KB)
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
inet6 addr: ::1/128 Scope:Host
UP LOOPBACK RUNNING MTU:65536 Metric:1
RX packets:12 errors:0 dropped:0 overruns:0 frame:0
TX packets:12 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1
RX bytes:680 (680.0 B) TX bytes:680 (680.0 B)
root@2d4eda315f4f:/# telnet localhost 6379
Trying ::1...
Trying 127.0.0.1...
telnet: Unable to connect to remote host: Connection refused
root@2d4eda315f4f:/# telnet 172.17.0.3 6379
Trying 172.17.0.3...
telnet: Unable to connect to remote host: Connection refused这是因为主机中没有可用的docker0接口吗?在开发环境中允许这些容器通信(在同一主机上运行时)有什么简单的解决办法吗?
更新:试图使用命名容器,我仍然无法连接。
docker run -d --name redis_server redis在以下方面的成果:
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
5d05820aa985 redis "docker-entrypoint.sh" 43 hours ago Up 1 seconds 6379/tcp redis_server但是如果我启动一个新的Ubuntu容器:
root@e92b47419bc4:/# redis-cli -h redis_server
Could not connect to Redis at redis_server:6379: Name or service not known我不知道如何找到/连接到第一个redis_server容器。
发布于 2017-01-03 05:38:45
每个容器都有自己的本地主机。
每个服务都在自己的容器中运行。从Ubuntu容器的角度来看,redis没有监听localhost。
使用码头网络
为了让您的集装箱进行通信,它们应该在同一个码头网络上。这包括三个步骤:
这样,容器就可以像主机名一样使用它们的名称相互交谈。
剥这只猫皮的方法不止一种.在这个答案中,我将看到两种方法,但可能还有一些我不熟悉的其他方法(例如使用Kubernetes或Swarm )。
用手做
您可以使用docker network命令为此应用程序创建网络。
# Show the current list of networks
docker network ls
# Create a network for your app
docker network create my_redis_app当您运行redis容器时,请确保它有一个名称,并且在这个网络上。如果您愿意(使用macOS),可以将端口对外公开(向-p),但这并不是其他容器与redis通信所必需的。
docker run -d -p 6379:6379 --name redis_server --network my_redis_app <IMAGE ID>现在运行您的Ubuntu容器。如果您愿意的话,您也可以给它命名,但是我不会在这个例子中费心,因为这个示例没有运行任何服务。
docker run -it --network my_redis_app ubuntu bash现在,从Ubuntu容器内部,您应该可以使用名称redis_server来访问redis,就像它是一个DNS名称一样。
用撰写来做
我倾向于使用Compose构建这样的设置,因为将其写入YAML文件(IMO)更容易。下面是上面的一个示例,用docker-compose.yml表单重写:
version: '2'
services:
redis:
image: <IMAGE ID>
networks:
- my_redis_app
ports: 6379:6379
ubuntu:
image: ubuntu:latest
networks:
- my_redis_app
networks:
my_redis_app:
driver: bridge在此基础上,您可以使用特定的Docker网络运行docker-compose up -d redis并使您的redis服务在线。如果网络还不存在的话,Compose将为您创建网络。
用这种方式运行Ubuntu容器就没什么意义了.当然,它是互动的。但是我假设一旦您有了redis,您将添加某种应用程序容器,也许还会添加像nginx这样的web代理.只需将其他部分放在services下,您就可以将它们全部管理起来。
由于ubuntu是交互式的,所以您可以交互地运行它:
# without -d, container is run interactively
docker-compose run ubuntu bash现在在Ubuntu中,您应该能够使用它的名称连接到redis,在本例中,这个名称就是redis。
https://stackoverflow.com/questions/41433411
复制相似问题