推广 热搜: 京东  联通  iphone11  摄像头  企业存储  XSKY  京东智能采购  iPhone  网络安全  自动驾驶 

云计算核心技术Docker教程:Docker使用macvla网络

   日期:2021-04-27     来源:TechWeb编译    作者:itcg    浏览:303    我要评论    
导读:某些应用程序,尤其是旧版应用程序或监视网络流量的应用程序,期望直接连接到物理网络。在这种情况下,可以使用macvlan网络驱动程序为每个容器的虚拟网络接口分配MAC地址,使其看起来像是直接连接到物理网络的物理网络接口。

某些应用程序,尤其是旧版应用程序或监视网络流量的应用程序,期望直接连接到物理网络。在这种情况下,可以使用macvlan网络驱动程序为每个容器的虚拟网络接口分配MAC地址,使其看起来像是直接连接到物理网络的物理网络接口。在这种情况下,您需要在Docker主机上指定用于的物理接口macvlan,以及的子网和网关macvlan。您甚至可以macvlan使用不同的物理网络接口隔离网络。请记住以下几点:

由于IP地址耗尽或“ VLAN传播”,很容易无意间损坏您的网络,在这种情况下,您的网络中有大量不正确的唯一MAC地址。

您的网络设备需要能够处理“混杂模式”,在该模式下,可以为一个物理接口分配多个MAC地址。

如果您的应用程序可以使用网桥(在单个Docker主机上)或覆盖(跨多个Docker主机进行通信)工作,那么从长远来看,这些解决方案可能会更好。

创建一个macvlan网络

创建macvlan网络时,它可以处于桥接模式或802.1q中继桥接模式。

在桥接模式下,macvlan流量通过主机上的物理设备。

在802.1q中继桥接模式下,流量通过Docker动态创建的802.1q子接口。这使您可以更精细地控制路由和过滤。

桥接模式

要创建macvlan与给定物理网络接口桥接的网络,请--driver macvlan与docker network create命令一起使用。您还需要指定parent,这是流量将在Docker主机上实际通过的接口。

$ docker network create -d macvlan

--subnet=172.16.86.0/24

--gateway=172.16.86.1

-o parent=eth0 pub_net

如果您需要排除IP地址在macvlan网络中的使用,例如当一个给定的IP地址已经在使用中时,请使用--aux-addresses:

$ docker network create -d macvlan

--subnet=192.168.32.0/24

--ip-range=192.168.32.128/25

--gateway=192.168.32.254

--aux-address="my-router=192.168.32.129"

-o parent=eth0 macnet32

802.1q中继桥接模式

如果您指定parent带有点的接口名称,例如eth0.50,则Docker会将其解释为的子接口,eth0并自动创建该子接口。

$ docker network create -d macvlan

--subnet=192.168.50.0/24

--gateway=192.168.50.1

-o parent=eth0.50 macvlan50

使用ipvlan代替

在上面的示例中,您仍在使用L3桥。您可以改用ipvlan L2桥接器。指定-o ipvlan_mode=l2。

$ docker network create -d ipvlan

--subnet=192.168.210.0/24

--subnet=192.168.212.0/24

--gateway=192.168.210.254

--gateway=192.168.212.254

-o ipvlan_mode=l2 -o parent=eth0 ipvlan210

 
反对 0举报 0 收藏 0 打赏 0评论 0
 
更多>同类资讯
0相关评论

头条阅读
推荐图文
相关资讯
网站首页  |  物流配送  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  RSS订阅  |  违规举报  |  京ICP备14047533号-2
Processed in 0.113 second(s), 11 queries, Memory 1.49 M