Docker端口映射与容器互联

我会带着你远行 2022-11-02 11:55 376阅读 0赞

Docker端口映射与容器互联

一、端口映射

在启动容器的时候,如果不指定对应参数,在容器外部是无法通过网络来访问容器内的 网络应用和服务的。

使用 -p 来指定映射规则: 3000:22 表示宿主的3000映射到容器的22端口, 使用多次 -p 可以映射多个端口.

  1. docker run -d -p 2222:22 -p 8888:80 centos_java8_sshd:1.0

查看容器端口绑定情况:

  1. docker port 9b2e0f3478ff

二、容器互相访问

端口映射并不是唯一把 docker 连接到另一个容器的方法。

docker 有一个连接系统允许将多个容器连接在一起,共享连接信息。

docker 连接会创建一个父子关系,其中父容器可以看到子容器的信息。

2.2.1容器命名

创建容器的时候, Docker会自动为容器分配一个随机的名字.我们也可以指定一个好记的名字, 方便容器间的互联.

  1. docker run -d --name hadoop102 centos_java8_sshd:1.0

说明:

  • –name 参数给容器起一个名字
    在这里插入图片描述

2.2.2docker的网络

docker还会给我们创建三个网络:bridge/host/none。我们可以通过network ls命令查看当前宿主机中所有的docker网络。

在这里插入图片描述

其中,网桥bridge模式是在实际项目中常用的。接下来,以交互模式启动两个centos_java8_sshd 容器。在没有指定相关网络的情况下,容器都会连接到默认的bridge网络.

创建两个容器: hadoo102和hadoop103, 检查bridge网络情况. 可以看到他们的ip地址.

  1. docker run -d --name hadoop102 centos_java8_sshd:1.0
  2. docker run -d --name hadoop103 centos_java8_sshd:1.0
  3. docker network inspect bridge

在这里插入图片描述

注意:

  1. 通过ip地址我们在宿主机或者容器之间可以访问到对方
    在这里插入图片描述
  2. 当是172.17.0.2 等这些ip地址不能固定, 每次启动容器的时候有可能会变化, 如果组建集群的话很不方便.

2.2.3自定义bridge网络, 实现容器间通讯

docker daemon 实现了一个内嵌的 DNS server,使容器可以直接通过“容器名”通信。使用默认的bridge网络,不能通过DNS server实现通过容器名通信,但是使用自定义bridge网络可以做到通过容器名互相通信

1.创建自定义bridge网络, 网络名hadoop

  1. docker network create --driver bridge hadoop

2.删除hadoop102和hadoop103容器

  1. docker rm -f hadoop102
  2. docker rm -f hadoop103

3.新建并启动hadoop102和hadoop103容器, 并加入到hadoop网络

  1. docker run -d --name hadoop102 --network hadoopcentos_java8_sshd:1.0
  2. docker run -d --name hadoop103 --network hadoopcentos_java8_sshd:1.0

在这里插入图片描述

4.进入hadoop102, 测试是否可以ping通hadoop103
在这里插入图片描述

发表评论

表情:
评论列表 (有 0 条评论,376人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Docker——端口映射容器互联

    端口映射实现容器访问 1. 从外部访问容器应用: 在启动容器的时候,如果不指定对应参数,在容器外部是无法通过网络来访问容器内的网络应用和服务的。 当容器中运行一些网络

    相关 Docker 容器互联

    随着 Docker 网络的完善,强烈建议大家将容器加入自定义的 Docker 网络来连接多个容器,而不是使用 `--link` 参数。