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
注意:
- 通过ip地址我们在宿主机或者容器之间可以访问到对方
- 当是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
还没有评论,来说两句吧...