Docker端口映射与容器互联

Docker端口映射与容器互联

一、端口映射

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

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

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

查看容器端口绑定情况:

docker port 9b2e0f3478ff

二、容器互相访问

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

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

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

2.2.1容器命名

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

	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地址.

docker run -d --name hadoop102 centos_java8_sshd:1.0
docker run -d --name hadoop103 centos_java8_sshd:1.0


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

docker network create --driver bridge hadoop

2.删除hadoop102和hadoop103容器

docker rm -f hadoop102
docker rm -f hadoop103

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

docker run -d --name hadoop102 --network hadoopcentos_java8_sshd:1.0
docker run -d --name hadoop103 --network hadoopcentos_java8_sshd:1.0

在这里插入图片描述

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值