当前位置: 首页 > 面试题库 >

macOS 10.12上两个Docker容器之间的通信

戚晨
2023-03-14
问题内容

我正在macOS 10.12上使用Docker 1.12.5,并且正在使用我设置一个开发环境,其中包含一个 应用程序 映像和一个共享的
Redis 映像,其中包含一些预先填充的配置变量。

即使遵循了一些教程(并阅读了docker0Mac上不可用的知识),我仍在努力连接两个容器。

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容器。


问题答案:

每个容器都有自己的本地主机

每个服务都在其自己的容器中运行。从Ubuntu容器的角度来看,redis未监听localhost。

使用Docker网络

为了使您的容器进行通信,它们应该在同一Docker网络上。这包括三个步骤:

  1. 创建一个Docker网络
  2. 提供您的容器名称
  3. 将容器连接到您创建的网络

完成此操作后,容器可以使用其名称彼此对话,就好像它们是主机名一样。

剥皮这只猫的方法不止一种…我将在这个答案中介绍两种,但是我可能还不了解其他几种方法(例如,使用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容器时,请确保它具有名称,并且在此网络上。如果需要(可以使用-p),可以在外部(对macOS)公开端口,但这仅是其他容器与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容器内部,您应该可以使用name来访问redis redis_server,就像它是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-compose up -d redis使用特定的Docker网络运行并使Redis服务联机。如果网络尚不存在,则Compose会为您创建网络。

以这种方式运行Ubuntu容器的意义不大……当然是交互式的。但是我认为一旦进行了Redis操作,您将添加某种应用程序容器,也许还会添加一个像nginx这样的Web代理…也只需将其他代理置于其中services,就可以将它们全部管理在一起。

由于ubuntu是交互式的,因此可以以交互方式运行它:

# without -d, container is run interactively
docker-compose run ubuntu bash

现在,在Ubuntu中,您应该能够使用其名称连接到Redis,在此示例中,该名称仅为redis



 类似资料:
  • 问题内容: 有两个Java文件,Server.java和Client.java。两者都放在单独的容器中。 DOCKER FILES: 我用于服务器的dockerfile(位于名为“ Server”的文件夹中)为: 客户端的dockerfile(位于名为``Client’‘的文件夹中)为: 构建容器: 使用以下容器构建容器 运行容器: 我使用命令运行图像。然后我首先运行serverimage。 我得

  • 问题内容: 两个单独的Docker容器是否可以通过ZMQ IPC套接字进行通信?如果是这样,如何实现? 例如: Docker容器1 执行一个应用程序,该应用程序创建ZMQ响应套接字并绑定到“ ipc:// tmp / service_name”。 Docker Container#2 执行一个应用程序,该应用程序创建一个ZMQ Request套接字并连接到“ ipc:// tmp / servic

  • 我有三个集装箱: 前(vuejs) 服务器(nodejs) mongo(mongodb) http://server:3000/MyGetRoute 注意:此路由可以从我的浏览器通过 http://localhost:3000/mygetroute

  • 我有2个Docker容器:App 应用程序-包含php应用程序代码的简单容器。它仅用于存储代码并将代码传递到远程Docker主机。 应用映像Dockerfile: Web服务容器,由PHP-FPM Nginx组成。 Web image Dockerfile: 我的问题:是否可以通过套接字链接Web容器和App容器? 主要原因是使用应用程序容器将更新的代码部署到远程Docker主机。使用卷/命名卷在

  • 我有两个项目,一个是aspnet核心API项目,另一个是xUnit e2e项目,两者都部署在两个不同的容器中。 一旦两个容器都启动并运行,e2e容器就会尝试在url上访问Web API项目的APIhttps://web-api-container:5010/.但e2e项目无法实现API项目。似乎无法使用其主机名访问API项目(http://web-api-container:5010/). 我的c

  • 问题内容: 我对Controllers and Views(fxml)进行了结构化,以尽可能地分隔我的代码,我想知道如何在2个控制器之间进行通信。我的意思是,一个控制器必须调用另一个控制器的某些功能才能将其设置为最新状态。 我认为我当前结构的模式将更加明确: 控制器1 / \ fx:include fx:include / \ Controller2 Controller3 每个控制器都有自己的f