docker网络(原生网络、自定义网络、容器间通信、外网访问容器、跨主机容器网络)

本文详细介绍了Docker的网络模型,包括原生的bridge、host和none模式,强调了桥接模式下容器的网络访问方式。接着探讨了自定义网络的创建与配置,如指定子网、网关和IP。此外,讲解了容器间的通信机制,如内嵌DNS服务器、使用--link以及joined方式。同时,阐述了如何使外部访问容器,以及跨主机容器网络的解决方案,如overlay、macvlan,并举例说明macvlan在网络层面的实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.docker原生网络

docker在安装好时会有3种网络模型:bridge(默认),host,none
docker network ls
**docker在安装好后会自动新建一个docker0的接口,所有的容器都会自动桥接到docker0 上 **
在这里插入图片描述
在这里插入图片描述


1.1 桥接模式

桥接模式下容器没有公共ip,只有宿主机可以访问,外部主机不可见。
容器要访问外网必须通 过宿主机的NAT规则,所以在物理机上需要打开ip_forward路由转发功能。
容器启动时,默认会生成一个网络对,一头连接容器,一头连接docker0,类似于网线的两端,实现了容器和宿主机的数据互通。

docker run -d --name nginx nginx
brctl show 可以看到桥接到了docker0上
在这里插入图片描述
在这里插入图片描述


1.2 host模式

host模式可以让容器共享宿主机的网络栈,可以让外部直接与容器通信,但是少了容器网络的隔离性。
docker run -it --name vm1 --network host ubuntu在容器内执行ipaddr,看到和宿主机一样的网卡信息
ip addr ##发现确实和容器内看到的一致

在这里插入图片描述

1.3 none模式(禁用网络模式)

有一些应用不需要连接外网,或者存放的数据是重要或秘密数据,可以使用none模式
docker run -it --name vm2 --network none ubuntu在容器内执行ipaddr,可以看到只有一个lo接口
在这里插入图片描述


2.docker自定义网络

三种网络驱动:
1.bridge(自定义的bridge带dns解析功能,可以 直接使用vm1vm2这种名字去访问,不一定要使用ip)
2.overlay
3.macvlan,后面两种用 于跨主机的网络,也就是集群等)

2.1 创建自定义网络

docker network create --help ##可以看到如果不指定驱动,默认使用bridge
docker network create -d bridge my_net1 创建一个名为 my_net1的自定义网络
docker network ls
docker run -it --name vm1 --network my_net1 ubuntu 运行容器, 可以看到分配了一个172.18网段的ip,容器的ip是单调递增,网段也是
docker network inspect my_net1

在这里插入图片描述
在这里插入图片描述


2.2 自定义网段、网关

docker ne

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值