docker网络模式详解

docker网络模式

bash 复制代码
#怎么进行查看Docker的网络模式
命令:Docker network ls  查看有几种网络模型
     docker inspect 容器名字   可以查看到容器的具体信息包含网络信息

怎么在创建容器的时候指定使用的网络模式
--net=网络模式

默认是使用的bridge桥接模式

bridge模式,默认模式

图解

容器共享独立的网络空间,通过nat的方式,转换成宿主机IP,与其他网络互通等同于vmware的nat模式,虚拟出来一个交换机,默认网段是172.17.0.0/16 网关是172.17.0.1调用iptables实现数据的转换

案例:创建nginx:alpine的容器,要求使用默认网络模式,容器的ip地址属于192.168.0.0/16,网关为192.168.0.1
php 复制代码
#1、先创建自定义网络
[root@docker ~]# docker network create -d bridge --subnet 192.168.0.0/16 --gateway 192.168.0.1 net_test
7e19dfe7741ae1af5912e03e17728a5f4d21f38d6c47d28940ac25e0a3476e88


 
[root@docker ~]# docker run -d --net net_test nginx:alpine
817b5319d49f4c1c691132e362d61b763561f7fab6de44cc4a598f34199e56ad
[root@docker ~]# docker inspect pedantic_proskuriakova | grep -i ipaddress
            "SecondaryIPAddresses": null,
            "IPAddress": "",
                    "IPAddress": "192.168.0.2",

host模式

图解

容器共享宿主机的网络空间,可以通过宿主机的网络空间(ip+port)直接访问容器会有安全隐患,不建议使用

案例:使用host模式运行mysql5.7的容器
php 复制代码
#运行容器
docker run -d --net host -e MYSQL_ROOT_PASSWORD=123 --name mysql mysql:5.7.32
    
#使用的是宿主机的IP
mysql -uroot -p123 -h'10.0.0.100' 

container模式

图解

容器没有独立的网络空间,共享指定容器的网络空间,创建的容器是进行使用指定容器的网络

php 复制代码
#运行容器
docker run -di --net container:mysql alpine sh

none模式

在none模式下,Docker容器拥有自己的网络命名空间,但是并不进行任何网络配置。该模式关闭了容器的网络功能,此时容器没有网卡、IP地址、路由等信息

自定义网络模式

除了docker默认的几种模式之外,我想单独创建一个桥接模式的网络模式,怎么创建

bash 复制代码
命令:
方法一:直接创建一个新的网络名称,默认是使用的桥接模式
docker network create my-custom-network
方法二:自己定义网络模式  使用的网段
docker network create \
  --driver bridge \          # 驱动类型,自定义桥接网络必须指定bridge
  --subnet 172.20.0.0/16 \   # 自定义子网(比如172.20.0.0/16)
  --gateway 172.20.0.1 \     # 网关地址(子网的第一个IP)
  --ip-range 172.20.0.0/24 \ # 容器分配的IP段(子集网)
  my-custom-network          # 自定义网络名称(可自定义,比如sms-network)


  #两个不同的网络模式网段想要正常通讯的话应该怎么做
  语法:docker network connect 哪个网络名称   哪个容器
  把哪个容器添加到对应的网络中允许进行通讯
相关推荐
北方的流星1 小时前
华三路由器NAT配置
运维·网络·华三
数据法师2 小时前
开源情报收集工具GhostTrack深度测评:IP、手机号、用户名的合规信息查询方案
网络·网络协议·tcp/ip
丑八怪大丑3 小时前
Java网络编程
linux·服务器·网络
想成为优秀工程师的爸爸3 小时前
第三十篇技术笔记:郭大侠学UDS - 人有生老三千疾,望闻问切良方医
网络·笔记·网络协议·tcp/ip·信息与通信
运维全栈笔记4 小时前
K8S部署Redis高可用全攻略:1主2从3哨兵架构实战
redis·docker·云原生·容器·架构·kubernetes·bootstrap
数智工坊4 小时前
【SAM-DETR论文阅读】:基于语义对齐匹配的DETR极速收敛检测框架
网络·论文阅读·人工智能·深度学习·transformer
时空自由民.5 小时前
蓝牙协议之GAP协议
linux·服务器·网络
SCBAiotAigc6 小时前
2026.5.1:`DockerDesktop must be owned by an elevated account`错误的解决办法
人工智能·docker·具身智能
灰子学技术6 小时前
Envoy HTTP Connection Manager (HCM) 技术文档
网络·网络协议·http
byoass6 小时前
企业云盘与设计软件深度集成:AutoCAD/Revit/SolidWorks插件开发与API集成实战
服务器·网络·数据库·安全·oracle·云计算