校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 詳解Docker 容器跨主機多網段通信解決方案

詳解Docker 容器跨主機多網段通信解決方案

熱門標簽:電銷機器人對公司貢獻 智能外呼系統如何部署 宿州防封外呼系統廠家 濟源電話外呼系統怎么樣 高德地圖標注在建線路 電話機器人服務差 蘭州語音電銷機器人軟件 山東400電話如何辦理 ai電銷機器人 如何開發

一、MacVlan

實現Docker的跨主機網絡通信的方案有很多,如之前博文中寫到的通過部署 Consul服務實現Docker容器跨主機通信

Macvlan工作原理:

Macvlan是Linux內核支持的網絡接口。要求的Linux內部版本是v3.9–3.19和4.0+;
通過為物理網卡創建Macvlan子接口,允許一塊物理網卡擁有多個獨立的MAC地址和IP地址。虛擬出來的子接口將直接暴露在相鄰物理網絡中。從外部看來,就像是把網線隔開多股,分別接受了不同的主機上一樣;
物理網卡收到包后,會根據收到包的目的MAC地址判斷這個包需要交給其中虛擬網卡。

當容器需要直連入物理網絡時,可以使用Macvlan。Macvlan本身不創建網絡,本質上首先使宿主機物理網卡工作在‘混雜模式',這樣物理網卡的MAC地址將會失效,所有二層網絡中的流量物理網卡都能收到。接下來就是在這張物理網卡上創建虛擬網卡,并為虛擬網卡指定MAC地址,實現一卡多用,在物理網絡看來,每張虛擬網卡都是一個單獨的接口。

使用Macvlan注意:

  • 容器直接連接物理網絡,由物理網絡負責分配IP地址,可能的結果是物理網絡IP地址被耗盡,另一個后果是網絡性能問題,物理網絡中接入的主機變多,廣播包占比快速升高而引起的網絡性能下降問題;
  • 宿主機上的某張網上需要工作在‘混亂模式'下;
  • 前面說到,工作在混亂模式下的物理網卡,其MAC地址會失效,所以,此模式中運行的容器并不能與外網進行通信,但是不會影響宿主機與外網通信;
  • 從長遠來看bridge網絡與overlay網絡是更好的選擇,原因就是虛擬網絡應該與物理網絡隔離而不是共享。

工作示意圖:


二、配置實例

實例1(實現容器基于macvlan的單網段跨主機通信)

實現效果:

兩臺centos 7.3,分別運行著docker服務;
兩臺docker服務器創建相同的一個MacVlan網絡,使docker服務器上的容器可以實現跨主機通信。

開始配置

1、第一臺docker服務器配置如下

[root@docker01 ~]# ip link set ens33 promisc on       # 開啟ens33網卡的混雜模式
[root@docker01 ~]# ip link show ens33   # 確定查看的信息包含以下標紅的字樣
2: ens33: <BROADCAST,MULTICAST,'PROMISC',UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP mode DEFAULT group default qlen 1000
  link/ether 00:0c:29:9f:33:9f brd ff:ff:ff:ff:ff:ff
[root@docker01 ~]# docker network create -d macvlan --subnet 172.22.16.0/24 --gateway 172.22.16.1 -o pa
rent=ens33 mac_net1
#創建macvlan網絡,指定網關、網段等信息,“-o”指定綁定在哪張網卡之上
[root@docker01 ~]# docker run -itd --name test1 --ip 172.22.16.10 --network mac_net1 busybox   # 基于新創建的macvlan網絡運行一個容器,并指定其IP

確認運行的容器的IP地址

[root@docker01 ~]# docker exec test1 ip a   # 查看IP,確定以下標紅與配置的一樣
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
  link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
  inet 127.0.0.1/8 scope host lo
    valid_lft forever preferred_lft forever
6: eth0@if2: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue 
  link/ether 02:42:ac:16:10:0a brd ff:ff:ff:ff:ff:ff
  inet '172.22.16.10/24' brd 172.22.16.255 scope global eth0
    valid_lft forever preferred_lft forever

2、第二臺docker服務器配置如下(與第一臺docker服務器基本相似)

[root@docker02 ~]# ip link set ens33 promisc on    # 開啟混雜模式
[root@docker02 ~]# ip link show ens33 
2: ens33: <BROADCAST,MULTICAST,'PROMISC',UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP mode DEFAULT group default qlen 1000
  link/ether 00:0c:29:b5:bc:ed brd ff:ff:ff:ff:ff:ff
[root@docker02 ~]# docker network create -d macvlan --subnet 172.22.16.0/24 --gateway=172.22.16.1 -o parent=ens33 mac_net1
#創建一個與第一臺docker服務器的網段、網關相同的macvlan。并綁定到物理網卡上。
#為了可以直觀的看出其他docker服務器上的macvlan和第這臺是在同一個網段的。所以,建議設置的網絡名稱一樣。
[root@docker02 ~]# docker run -itd --name test2 --ip 172.22.16.11 --network mac_net1 busybox
#運行一個容器,并指定是基于macvlan網絡的
#注意,其IP地址不要與其他docker服務器上的容器IP地址沖突

確認運行的容器的IP地址

[root@docker02 ~]# docker exec test2 ip a
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
  link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
  inet 127.0.0.1/8 scope host lo
    valid_lft forever preferred_lft forever
6: eth0@if2: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue 
  link/ether 02:42:ac:16:10:0b brd ff:ff:ff:ff:ff:ff
  inet '172.22.16.11/24' brd 172.22.16.255 scope global eth0
    valid_lft forever preferred_lft forever

使用第二臺docker服務器上的容器test2對第一臺docker服務器上的容器test1進行ping測試


OK,跨主機的容器通信就通過macvlan實現了。由于使用混雜模式會造成物理網卡的MAC地址失效,所以容器并不能通過此模式進行與外網的通信。

實例2(基于macvlan的跨主機網絡多網段的解決方案)

實現的效果如下:

  • 兩臺centos 7.3,分別運行著docker服務;
  • 每臺宿主機創建了兩個MacVlan網段供容器使用(172.10.16.0/24和172.20.16.0/24);
  • 第一臺docker服務器上運行容器test1和test2,第二臺docker服務器運行容器test3和test4。
  • 最終實現跨主機的同網段容器互相通信。

開始配置:

1、第一臺docker服務器配置如下

[root@docker01 ~]# ip link set ens33 promisc on       # 開啟ens33網卡的混雜模式
#也就是開啟網卡的多個虛擬interface(接口) 
[root@docker01 ~]# ip link show ens33   # 確定查看的信息包含以下標紅的字樣
2: ens33: <BROADCAST,MULTICAST,'PROMISC',UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP mode DEFAULT group default qlen 1000
  link/ether 00:0c:29:9f:33:9f brd ff:ff:ff:ff:ff:ff
[root@docker01 ~]# modinfo 8021q
 #查看是否加載8021q模塊,如果有信息返回,則表示該模塊已經加載

modinfo 8021q命令返回的信息如下

[root@docker01 ~]# modprobe 8021q   #若沒有加載8021q模塊,則執行此命令
[root@docker01 ~]# cd /etc/sysconfig/network-scripts/
[root@docker01 network-scripts]# vim ifcfg-ens33 
           ...................
BOOTPROTO=manual       # 將此配置項改為“manual”,也是手動的意思
[root@docker01 network-scripts]# cp -p ifcfg-ens33 ifcfg-ens33.10       # 復制一份網卡配置文件,-p保留原本文件的屬性
[root@docker01 network-scripts]# vim ifcfg-ens33.10 
BOOTPROTO=none 
NAME=ens33.10        #注意更改名稱
DEVICE=ens33.10   #注意更改名稱
ONBOOT=yes
IPADDR=192.168.10.11       # 給虛擬網卡設置一個IP
PREFIX=24
GATEWAY=192.168.10.2
VLAN=yes
[root@docker01 network-scripts]# cp ifcfg-ens33.10 ifcfg-ens33.20 
[root@docker01 network-scripts]# vim ifcfg-ens33.20 
BOOTPROTO=none
NAME=ens33.20
DEVICE=ens33.20
ONBOOT=yes
IPADDR=192.168.20.10        # 注意,此處的IP與ens33.10并不在同一網段
PREFIX=24
GATEWAY=192.168.20.2
VLAN=yes
[root@docker01 network-scripts]# ifdown ens33;ifup ens33     #重啟網卡,使更改生效
[root@docker01 network-scripts]# ifup ens33.10   # 啟動該網卡
[root@docker01 network-scripts]# ifup ens33.20   # 啟動
[root@docker01 ~]# docker network create -d macvlan --subnet 172.10.16.0/24 --gateway 172.10.16.1 -o parent=ens33.10 mac_net10
#創建一個macvlan網絡,給其定義一個網段、網關及綁定到ens33.10
[root@docker01 ~]# docker network create -d macvlan --subnet 172.20.16.0/24 --gateway 172.20.16.1 -o parent=ens33.20 mac_net20
#創建一個macvlan網絡,給其定義一個網段、網關及綁定到ens33.20
#接下來分別基于剛剛創建的macvlan網絡運行一個容器

2、第二臺docker服務器配置如下(基本與第一臺操作類似,要注意IP不要沖突)

[root@docker02 ~]# ip link set ens33 promisc on    # 開啟混雜模式
[root@docker02 ~]# ip link show ens33 
2: ens33: <BROADCAST,MULTICAST,'PROMISC',UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP mode DEFAULT group default qlen 1000
  link/ether 00:0c:29:b5:bc:ed brd ff:ff:ff:ff:ff:ff
[root@docker02 ~]# modinfo 8021q
返回信息可參考圖一
[root@docker02 ~]# modprobe 8021q   #若沒有加載8021q模塊,則執行此命令
[root@docker02 ~]# cd /etc/sysconfig/network-scripts/
[root@docker02 network-scripts]# vim ifcfg-ens33 
      ...............#省略部分內容
BOOTPROTO=manual    
[root@docker02 network-scripts]# scp root@192.168.171.151:/etc/sysconfig/network-scripts/ifcfg-ens33.* .         # 要注意后面的“.”
ifcfg-ens33.10                            100% 128  83.4KB/s  00:00  
ifcfg-ens33.20                            100% 124  75.0KB/s  00:00 
[root@docker02 network-scripts]# vim ifcfg-ens33.10 
BOOTPROTO=none
NAME=ens33.10
DEVICE=ens33.10
ONBOOT=yes
IPADDR=192.168.10.11      # 更改IP,以防和第一臺沖突
PREFIX=24
GATEWAY=192.168.10.2
VLAN=yes
[root@docker02 network-scripts]# vim ifcfg-ens33.20 

BOOTPROTO=none
NAME=ens33.20
DEVICE=ens33.20
ONBOOT=yes
IPADDR=192.168.20.11
PREFIX=24
GATEWAY=192.168.20.2
VLAN=yes
[root@docker02 network-scripts]# ifdown ens33;ifup ens33     # 重啟網卡 ,使配置生效
[root@docker02 network-scripts]# ifup ens33.10   # 啟動網卡
[root@docker02 network-scripts]# ifup ens33.20
#接下來創建macvlan網絡,與第一臺docker服務器創建的網絡一樣
[root@docker02 ~]# docker network create -d macvlan --subnet 172.10.16.0/24 --gateway 172.10.16.1 -o parent=ens33.10 mac_net10
[root@docker02 ~]# docker network create -d macvlan --subnet 172.20.16.0/24 --gateway 172.20.16.1 -o parent=ens33.20 mac_net20 
[root@docker02 ~]# docker run -itd --name test3 --network mac_net10 --ip 172.10.16.11 busybox
[root@docker02 ~]# docker run -itd --name test4 --network mac_net20 --ip 172.20.16.21 busybox

配置至此,即可進行ping測試了,如果配置無誤,則test3應該和test1互通(因為其都是基于mac_net10網絡);test4應該和test2互通(同理)。

但test3和test1不能和test4和test2互通(因為其不是基于同一個虛擬局域網)。

容器test3 ping 容器test1測試(注意:若是使用vmware虛擬機進行測試,由于vmware的特性,需將其網絡適配器改為“橋接模式”,而不是NAT模式等。否則無法通信)


容器test4 ping 容器test2測試:


至此,跨主機網絡多網段已經實現,同樣,各個容器無法與外網進行通信。若有耐心,還是建議閱讀docker官方文檔

到此這篇關于Docker 容器跨主機多網段通信解決方案的文章就介紹到這了,更多相關Docker 容器跨主機多網段通信內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

標簽:巴中 佛山 南寧 安陽 衡水 晉中 畢節 云南

巨人網絡通訊聲明:本文標題《詳解Docker 容器跨主機多網段通信解決方案》,本文關鍵詞  詳解,Docker,容器,跨,主機,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解Docker 容器跨主機多網段通信解決方案》相關的同類信息!
  • 本頁收集關于詳解Docker 容器跨主機多網段通信解決方案的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    午夜精品福利在线| 久久久久久免费网| 91精品免费观看| 国产午夜亚洲精品不卡| 天天色图综合网| 91免费版在线| 亚洲国产精品精华液ab| 精品一区二区三区的国产在线播放 | 久久精品久久精品| 欧美在线制服丝袜| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲国产成人porn| 色综合欧美在线视频区| 久久亚洲私人国产精品va媚药| 亚洲成人av一区二区三区| 99国产精品久| 欧美国产成人在线| 国产高清不卡二三区| 日韩一区二区三区av| 天天色 色综合| 欧美日韩国产成人在线免费| 亚洲黄色小视频| 成人动漫一区二区三区| 久久久国产一区二区三区四区小说 | 欧美伦理电影网| 亚洲一区二区三区四区在线免费观看 | 精品综合免费视频观看| 51精品国自产在线| 日韩福利视频网| 欧美一级欧美三级| 免费的成人av| 精品久久久久99| 精品一区二区精品| 久久综合狠狠综合久久激情 | 国产午夜精品在线观看| 国产不卡视频一区二区三区| 欧美激情中文不卡| aaa亚洲精品| 亚洲国产成人va在线观看天堂| 色综合天天视频在线观看| 亚洲视频小说图片| 91亚洲精品一区二区乱码| 亚洲高清在线视频| 日韩欧美第一区| 国v精品久久久网| 亚洲丝袜精品丝袜在线| 色婷婷狠狠综合| 日韩专区一卡二卡| 久久影院午夜论| 91视视频在线观看入口直接观看www | 国产亚洲短视频| 成人动漫一区二区三区| 一区二区三区电影在线播| 欧美剧情电影在线观看完整版免费励志电影 | 欧美无砖专区一中文字| 天天色 色综合| 久久久久亚洲蜜桃| 色婷婷久久99综合精品jk白丝| 亚洲一区电影777| 精品毛片乱码1区2区3区| 成人av综合在线| 五月天亚洲精品| 国产校园另类小说区| 日本丶国产丶欧美色综合| 午夜成人免费电影| 日本一区二区三区国色天香| 欧洲精品中文字幕| 国产精品一区二区果冻传媒| 亚洲激情在线播放| 久久久国产精品不卡| 欧美三级韩国三级日本一级| 国产精品一区二区在线看| 亚洲电影中文字幕在线观看| 亚洲精品一区二区三区四区高清| 99在线精品观看| 久久精品国产77777蜜臀| 成人欧美一区二区三区| 日韩免费观看高清完整版在线观看| 成人美女视频在线观看18| 免费成人在线视频观看| 亚洲乱码日产精品bd| 亚洲精品一线二线三线| 在线观看视频欧美| 成人ar影院免费观看视频| 日韩综合小视频| 一区二区三区.www| 依依成人综合视频| 久久久久免费观看| 精品蜜桃在线看| 91精品国产入口| 欧美日韩中文精品| 色屁屁一区二区| 99精品欧美一区| 成人高清在线视频| 国产高清久久久| 国产又黄又大久久| 另类欧美日韩国产在线| 亚洲一卡二卡三卡四卡五卡| 中文字幕中文字幕一区| 久久九九久久九九| 精品av综合导航| 日韩亚洲欧美高清| 欧美一卡2卡3卡4卡| 欧美日韩情趣电影| 在线观看不卡一区| 在线观看欧美日本| 欧美在线观看18| 欧洲中文字幕精品| 色欧美片视频在线观看| 91网站黄www| 色88888久久久久久影院按摩| 风间由美性色一区二区三区| 国产精品一二三在| 成人午夜激情视频| jvid福利写真一区二区三区| 成人国产精品免费观看动漫| 99久久er热在这里只有精品66| 成人午夜伦理影院| aaa亚洲精品| 欧美影院一区二区| 欧美一区二区久久| 精品日韩99亚洲| 欧美国产日韩精品免费观看| 国产欧美日韩久久| 亚洲欧美综合在线精品| 亚洲精品视频一区| 午夜视频在线观看一区| 日日摸夜夜添夜夜添精品视频| 日韩高清不卡一区二区三区| 久久99精品国产.久久久久久| 国产在线麻豆精品观看| 成人免费观看av| 91老师片黄在线观看| 欧美久久免费观看| 精品福利一二区| 国产精品国产成人国产三级| 一区二区三区精品在线观看| 天堂成人国产精品一区| 国产一区二区三区美女| 色婷婷综合久久久久中文一区二区 | xvideos.蜜桃一区二区| 国产精品你懂的在线欣赏| 一区2区3区在线看| 免费观看成人av| 成人少妇影院yyyy| 在线免费观看成人短视频| 欧美人妇做爰xxxⅹ性高电影| 精品久久久久久亚洲综合网| 亚洲视频一区在线| 青青草精品视频| 丁香婷婷综合色啪| 欧美精品自拍偷拍动漫精品| 国产亚洲欧美一区在线观看| 亚洲激情五月婷婷| 国内精品久久久久影院一蜜桃| 91视频在线看| 日韩午夜激情av| 亚洲五月六月丁香激情| 国产成人av资源| 777午夜精品免费视频| 欧美一区二区免费观在线| 亚洲一区在线电影| 韩国一区二区视频| 欧美自拍偷拍午夜视频| 久久午夜色播影院免费高清| 亚洲综合免费观看高清在线观看| 久久精品国产精品青草| 成人精品一区二区三区四区| 欧美挠脚心视频网站| 国产精品色在线| 麻豆国产精品一区二区三区| 成人a区在线观看| 国产精品福利av| 国产精品欧美久久久久无广告 | 91在线视频在线| 日韩欧美综合一区| 亚洲第一搞黄网站| 91猫先生在线| 国产精品久久久久永久免费观看 | 国产精品欧美精品| 精品一二三四区| 欧美一级欧美三级在线观看| 亚洲一区二三区| 日本精品一级二级| 中文字幕在线观看不卡| 国产精品一区二区无线| 亚洲精品一线二线三线无人区| 日本视频一区二区三区| 欧美日韩电影一区| 亚洲国产日日夜夜| 欧美色综合影院| 亚洲一区在线免费观看| 色综合欧美在线| 亚洲人被黑人高潮完整版| 成人av网址在线观看| 欧美国产精品久久| 成人精品国产一区二区4080| 国产精品毛片无遮挡高清| 顶级嫩模精品视频在线看| 国产精品久久久久久久午夜片 |