默认情况下Docker的网络模式为Bridge,当Docker进程启动时,会在主机上创建一个名为docker0的虚拟网桥,此主机上启动的Docker容器会连接到这个虚拟网桥上 。从docker0子网中分配一个IP给容器使用,并设置docker0的IP地址为容器的默认网关 。这样容器间就可以相互通信 。但是此种方式可能随着容器的重启的原因,ip发生变化 。(比如容器1开始ip为192.168.0.110,重启后变成了192.168.0.121) 。如何解决这个问题呢?
第一种:使用link实现容器互通
创建一个Nginx容器
【docker中容器如何实现通信】docker run -d --name nginx -p 80:80 -p 8080:8080 7743d9092020
文章插图
创建一个nginx容器
创建容器2并添加link
docker run -d --name to2 --link nginx 94e31e5297d1
文章插图
容器2
进入创建的容器查看hosts
docker exec to2 cat /etc/hosts
文章插图
查看hosts
查看环境变量env
docker exec to2 env
文章插图
查看env
查看在to2容器中是否可以ping的通nginx容器
文章插图
ping
此种方式的缺点是第一个容器不能使用link,因为在他上面没有容器了 。所以此种方式的缺点还是大大的存在 。如何避免呢?通过自定义网络 。
第二种:自定义网络
创建一个共享网络
docker network create --subnet=172.18.0.0/24 net1
文章插图
创建共享网络
--subnet是定义网段
创建容器指定共享网络,ip,和别名
docker run -d --name to1 --net=net1 --ip 172.18.0.2 --net-alias tom1 94e31e5297d1
按此种方式创建2个容器文章插图
创建容器
查看net1网络
文章插图
查看net1网络
容器已经在这里定义好了,这样即使启动也不会改变IP了 。进入to1通过别名ping一下 。
文章插图
ping
总结:
第一种方式由于有一个容器是不能设置link的,所以此种方式已经开始慢慢没人使用了,更多的是采用自定义网络来实现 。
推荐阅读
- 云南中吉号引领普洱茶投资新模式
- Docker配置阿里云镜像服务
- 上演茶酒对话 中国国际食品文化节明日开幕
- 中国茶道之三,禅茶味悟佛境
- 狗作为宠物的历史 中国古代对狗的看法
- 世界上出土古人类遗骨和遗址最丰富的遗址是 在中国的一些早期遗址中发现了世界上最早的什么
- 金芽奖鼎力打造中国茶品牌崛起之平台
- 中华武夷茶博园200余家企业邀您品茗会友
- 云雾山中出好茶 大坪坦村生态茶走俏市场
- 安溪茶企坚持传统纸包茶叶 准备申请中华老字号