掌握CentOS7环境下的Docker使用(五)Docker容器的网络模式

Docker容器的网络模式

默认的三种网络模式:

  • bridge:桥接模式
  • host:主机模式
  • none:无网络模式

查看网络模式:docker network ls
在这里插入图片描述
查看ifconfig:
在这里插入图片描述

Docker桥接网络模式

ens32是宿主机的网卡,docker0是docker服务启动的时候创建的虚拟网桥,并选择一个和宿主机不同的ip地址和子网分配给网桥

当网络模式选择桥接模式时,就会连接docker0这个虚拟网桥,通过NAT的转换,连接宿主机的网卡去连接外网

在这里插入图片描述

每新启动一个容器,网卡就会增加一个:
启动四个容器
在这里插入图片描述

增加了四个网卡
在这里插入图片描述
在这里插入图片描述

验证是否所有容器都桥接到docker0网卡:
进入一个centos:7镜像的docker容器中,使用route -n查看路由,使用ifconfig查看ip
在这里插入图片描述
在这里插入图片描述

匹配到的所有任何ip地址(0.0.0.0)都会发往172.17.0.1,退出容器后可以看见docker0的虚拟网桥就是172.17.0.1
在这里插入图片描述

安装yum install -y bridge-utils查看机器的桥接情况:brctl show
在这里插入图片描述

外部的机器想要访问docker容器也必须先通过宿主机才可以,不能直接访问到docker容器,验证:
运行一个nginx容器,在外部ping不通
在这里插入图片描述
但可以ping通宿主机
在这里插入图片描述

Docker主机host网络模式

host 模式:该模式下容器是不会拥有自己的ip地址,而是使用宿主机的ip地址和端口。

  • 网络性能比桥接模式好
  • host模式容器占用了80端口后,宿主机将无法使用80端口

启动nginx容器命令:
docker run -d --net=host mycentos:nginx /usr/local/nginx/sbin/nginx -g "daemon off;"
可以看见宿主机并没有多出虚拟机网卡:
在这里插入图片描述

host模式容器使用的是宿主机的ip地址和端口,可以访问宿主机ip验证是否能访问到nginx(防火墙开启状态下访问):
查看防火墙状态:firewall-cmd --state
查看80端口占用情况:netstat -tunlp | grep 80
在这里插入图片描述
80端口被docker容器占用,把端口放开
防火墙放开80端口:
firewall-cmd --zone=public --add-port=80/tcp --permanent
firewall-cmd --reload
在这里插入图片描述
可以访问到

注意:如果容器不以host模式启动运行,则外部是无法访问到的

Docker的none模式

none模式:关闭模式
无法连外网,相当于断网状态

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

豆浆两块钱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值