掌握CentOS7环境下的Docker使用(五)Docker容器的网络模式
创始人
2025-05-29 08:00:12

文章目录

  • Docker容器的网络模式
  • Docker桥接网络模式
  • Docker主机host网络模式
  • Docker的none模式

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模式:关闭模式
无法连外网,相当于断网状态

相关内容

热门资讯

四川卷高考作文解析及(优质3... 四川卷高考作文解析及 篇一四川卷高考作文解析及应对策略四川卷高考作文一直以其独特的题材和考查角度而备...
江苏省高考满分作文(精彩6篇... 江苏省高考满分作文 篇一:我的梦想梦想是每个人内心最深处的渴望,它是我们前进的动力和奋斗的目标。而我...
励志高考素材:无四肢的演讲大... 励志高考素材:无四肢的演讲大师尼克胡哲 篇一尼克胡哲,一个没有四肢的演讲大师,他的故事令人动容,充满...
高考英语考点形容词副词分析【... 高考英语考点形容词副词分析 篇一形容词和副词是英语中非常重要的词类,它们能够为我们的语言增添更多的细...
原创 印... 当地时间15日,美国总统川普宣布, “我与印尼备受尊敬的总统直接谈判,刚刚达成了一项对大家都很棒的协...