成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Docker 網(wǎng)絡模型之 macvlan 詳解,圖解,實驗完整

Ajian / 2864人閱讀

摘要:首先分別在兩臺主機上將物理網(wǎng)口創(chuàng)建出兩個子接口。然后創(chuàng)建兩個子接口,一個作為網(wǎng)絡的網(wǎng)關,一個作為的網(wǎng)關。對子接口配置網(wǎng)關并啟用這樣之后再從和,就可以通了。

本文首發(fā)于我的公眾號 Linux云計算網(wǎng)絡(id: cloud_dev),專注于干貨分享,號內有 10T 書籍和視頻資源,后臺回復「1024」即可領取,歡迎大家關注,二維碼文末可以掃。

上一篇文章我們詳細介紹了 macvlan 這種技術,macvlan 詳解,由于它高效易配置的特性,被用在了 Docker 的網(wǎng)絡方案設計中,這篇文章就來說說這個。

01 macvlan 用于 Docker 網(wǎng)絡

在 Docker 中,macvlan 是眾多 Docker 網(wǎng)絡模型中的一種,并且是一種跨主機的網(wǎng)絡模型,作為一種驅動(driver)啟用(-d 參數(shù)指定),Docker macvlan 只支持 bridge 模式。

下面我們做兩個實驗,分別驗證相同 macvlan 網(wǎng)絡和不同 macvlan 網(wǎng)絡的連通性。

1.1 相同 macvlan 網(wǎng)絡之間的通信

首先準備兩個主機節(jié)點的 Docker 環(huán)境,搭建如下拓撲圖示:

1 首先使用 docker network create 分別在兩臺主機上創(chuàng)建兩個 macvlan 網(wǎng)絡:

root@ubuntu:~# docker network create -d macvlan --subnet=172.16.10.0/24 --gateway=172.16.10.1 -o parent=enp0s8 mac1

這條命令中,

-d 指定 Docker 網(wǎng)絡 driver

--subnet 指定 macvlan 網(wǎng)絡所在的網(wǎng)絡

--gateway 指定網(wǎng)關

-o parent 指定用來分配 macvlan 網(wǎng)絡的物理網(wǎng)卡

之后可以看到當前主機的網(wǎng)絡環(huán)境,其中出現(xiàn)了 macvlan 網(wǎng)絡:

root@ubuntu:~# docker network ls
NETWORK ID          NAME                DRIVER              SCOPE
128956db798a        bridge              bridge              local
19fb1af129e6        host                host                local
2509b3717813        mac1                macvlan             local
d5b0798e725e        none                null                local

2 在 host1 運行容器 c1,并指定使用 macvlan 網(wǎng)絡:

root@ubuntu:~# docker run -itd --name c1 --ip=172.16.10.2 --network mac1 busybox

這條命令中,

--ip 指定容器 c1 使用的 IP,這樣做的目的是防止自動分配,造成 IP 沖突

--network 指定 macvlan 網(wǎng)絡

同樣在 host2 中運行容器 c2:

root@ubuntu:~# docker run -itd --name c2 --ip=172.16.10.3 --network mac1 busybox

3 在 host1 c1 中 ping host2 c2:

root@ubuntu:~# docker exec c1 ping -c 2 172.16.10.3
PING 172.16.10.3 (172.16.10.3): 56 data bytes
64 bytes from 172.16.10.3: seq=0 ttl=64 time=0.641 ms
64 bytes from 172.16.10.3: seq=1 ttl=64 time=0.393 ms

--- 172.16.10.3 ping statistics ---
2 packets transmitted, 2 packets received, 0% packet loss

round-trip min/avg/max = 0.393/0.517/0.641 ms
注意:以上的實驗都需要物理網(wǎng)卡 enp0s8 開啟混雜模式,不然會 ping 不通。
1.2 不同 macvlan 網(wǎng)絡之間的通信

接下來,我們來看看不同 macvlan 網(wǎng)絡之間的連通性,搭建以下的拓撲環(huán)境:

由于 macvlan 網(wǎng)絡會獨占物理網(wǎng)卡,也就是說一張物理網(wǎng)卡只能創(chuàng)建一個 macvlan 網(wǎng)絡,如果我們想創(chuàng)建多個 macvlan 網(wǎng)絡就得用多張網(wǎng)卡,但主機的物理網(wǎng)卡是有限的,怎么辦呢?

好在 macvlan 網(wǎng)絡也是支持 VLAN 子接口的,所以,我們可以通過 VLAN 技術將一個網(wǎng)口劃分出多個子網(wǎng)口,這樣就可以基于子網(wǎng)口來創(chuàng)建 macvlan 網(wǎng)絡了,下面是具體的創(chuàng)建過程。

1 首先分別在兩臺主機上將物理網(wǎng)口 enp0s8 創(chuàng)建出兩個 VLAN 子接口。

# 使用 vconfig 命令在 eth0 配置兩個 VLAN
root@ubuntu:~# vconfig add enp0s8 100
root@ubuntu:~# vconfig add enp0s8 200

# 設置 VLAN 的 REORDER_HDR 參數(shù),默認就行了
root@ubuntu:~# vconfig set_flag enp0s8.100 1 1
root@ubuntu:~# vconfig set_flag enp0s8.200 1 1

# 啟用接口
root@ubuntu:~# ifconfig enp0s8.100 up
root@ubuntu:~# ifconfig enp0s8.200 up

2 分別在 host1 和 host2 上基于兩個 VLAN 子接口創(chuàng)建 2 個 macvlan 網(wǎng)絡,mac10 和 mac20。

root@ubuntu:~# docker network create -d macvlan --subnet=172.16.10.0/24 --gateway=172.16.10.1 -o parent=enp0s8.100 mac10
root@ubuntu:~# docker network create -d macvlan --subnet=172.16.20.0/24 --gateway=172.16.20.1 -o parent=enp0s8.200 mac20

3 分別在 host1 和 host2 上運行容器,并指定不同的 macvlan 網(wǎng)絡。

# host1
root@ubuntu:~# docker run -itd --name d1 --ip=172.16.10.10 --network mac10 busybox
root@ubuntu:~# docker run -itd --name d2 --ip=172.16.20.10 --network mac20 busybox

# host2 
root@ubuntu:~# docker run -itd --name d3 --ip=172.16.10.11 --network mac10 busybox
root@ubuntu:~# docker run -itd --name d4 --ip=172.16.20.11 --network mac20 busybox

通過驗證,d1 和 d3,d2 和 d4 在同一 macvlan 網(wǎng)絡下,互相可以 ping 通,d1 和 d2,d1 和 d4 在不同的 macvlan 網(wǎng)絡下,互相 ping 不通。

這個原因也很明確,不同 macvlan 網(wǎng)絡處于不同的網(wǎng)絡,而且通過 VLAN 隔離,自然 ping 不了。

但這也只是在二層上通不了,通過三層的路由是可以通的,我們這就來驗證下。

重新找一臺主機 host3,通過打開 ip_forward 把它改造成一臺路由器(至于為什么可以這樣,可以參考我之前的一篇文章),用來打通兩個 macvlan 網(wǎng)絡,大概的圖示如下所示:

1 首先對 host3 執(zhí)行 sysctl -w net.ipv4.ip_forward=1 打開路由開關。

2 然后創(chuàng)建兩個 VLAN 子接口,一個作為 macvlan 網(wǎng)絡 mac10 的網(wǎng)關,一個作為 mac20 的網(wǎng)關。

[root@localhost ~]# vconfig add enp0s8 100
[root@localhost ~]# vconfig add enp0s8 200
[root@localhost ~]# vconfig set_flag enp0s8.100 1 1
[root@localhost ~]# vconfig set_flag enp0s8.200 1 1

# 對 vlan 子接口配置網(wǎng)關 IP 并啟用
[root@localhost ~]# ifconfig enp0s8.100 172.16.10.1 netmask 255.255.255.0 up
[root@localhost ~]# ifconfig enp0s8.200 172.16.20.1 netmask 255.255.255.0 up

3 這樣之后再從 d1 ping d2 和 d4,就可以 ping 通了。

root@ubuntu:~# docker exec d1 ping -c 2 172.16.20.10
PING 172.16.20.10 (172.16.20.10): 56 data bytes
64 bytes from 172.16.20.10: seq=0 ttl=63 time=0.661 ms
64 bytes from 172.16.20.10: seq=1 ttl=63 time=0.717 ms

--- 172.16.20.10 ping statistics ---
2 packets transmitted, 2 packets received, 0% packet loss
round-trip min/avg/max = 0.661/0.689/0.717 ms
root@ubuntu:~# docker exec d1 ping -c 2 172.16.20.11
PING 172.16.20.11 (172.16.20.11): 56 data bytes
64 bytes from 172.16.20.11: seq=0 ttl=63 time=0.548 ms
64 bytes from 172.16.20.11: seq=1 ttl=63 time=0.529 ms

--- 172.16.20.11 ping statistics ---
2 packets transmitted, 2 packets received, 0% packet loss
round-trip min/avg/max = 0.529/0.538/0.548 ms

PS:可能有些系統(tǒng)做了安全限制,可能 ping 不通,這時候可以添加以下 iptables 規(guī)則,目的是讓系統(tǒng)能夠轉發(fā)不通 VLAN 的數(shù)據(jù)包。

iptables -t nat -A POSTROUTING -o enp0s8.100 -j MASQUERADE

iptables -t nat -A POSTROUTING -oenp0s8.200 -j MASQUERADE

iptables -A FORWARD -i enp0s8.100 -o enp0s8.200 -m state --state RELATED,ESTABLISHED -j ACCEPT

iptables -A FORWARD -i enp0s8.200 -o enp0s8.100 -m state --state RELATED,ESTABLISHED -j ACCEPT


iptables -A FORWARD -i enp0s8.100 -o enp0s8.200 -j ACCEPT

iptables -A FORWARD -i enp0s8.200 -o enp0s8.100 -j ACCEPT

為什么配置 VLAN 子接口,配上 IP 就可以通了,我們可以看下路由表就知道了。

首先看容器 d1 的路由:

root@ubuntu:~# docker exec d1 ip route
default via 172.16.10.1 dev eth0 
172.16.10.0/24 dev eth0 scope link  src 172.16.10.10

我們在創(chuàng)建容器的時候指定了網(wǎng)關 172.16.10.1,所以數(shù)據(jù)包自然會被路由到 host3 的接口。再來看下 host3 的路由:

[root@localhost ~]# ip route
default via 192.168.108.1 dev enp0s3 proto dhcp metric 100 
172.16.10.0/24 dev enp0s8.100 proto kernel scope link src 172.16.10.1 
172.16.20.0/24 dev enp0s8.200 proto kernel scope link src 172.16.20.1 
192.168.56.0/24 dev enp0s8 proto kernel scope link src 192.168.56.122 metric 101 
192.168.108.0/24 dev enp0s3 proto kernel scope link src 192.168.108.2 metric 100

可以看到,去往 172.16.10.0/24 網(wǎng)段的數(shù)據(jù)包會從 enp0s8.100 出去,同理 172.16.20.0/24 網(wǎng)段也是,再加上 host3 的 ip_forward 打開,這就打通了兩個 macvlan 網(wǎng)絡之間的通路。

02 總結

macvlan 是一種網(wǎng)卡虛擬化技術,能夠將一張網(wǎng)卡虛擬出多張網(wǎng)卡。

macvlan 的四種通信模式,常用模式是 bridge。

在 Docker 中,macvlan 只支持 bridge 模式。

相同 macvlan 可以通信,不同 macvlan 二層無法通信,可以借助三層路由完成通信。

思考一下:

macvlan bridge 和 bridge 的異同點

還有一種類似的技術,多張?zhí)摂M網(wǎng)卡共享相同 MAC 地址,但有獨立的 IP 地址,這是什么技術?


后臺回復“加群”,帶你進入高手如云交流群

我的公眾號 「Linux云計算網(wǎng)絡」(id: cloud_dev) ,號內有 10T 書籍和視頻資源,后臺回復 「1024」 即可領取,分享的內容包括但不限于 Linux、網(wǎng)絡、云計算虛擬化、容器Docker、OpenStack、Kubernetes、工具、SDN、OVS、DPDK、Go、Python、C/C++編程技術等內容,歡迎大家關注。


參考:

https://www.cnblogs.com/Cloud...

https://blog.csdn.net/dog250/...

https://www.hi-linux.com/post...

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/11501.html

相關文章

  • Docker 網(wǎng)絡模型 macvlan 詳解,圖解,實驗完整

    摘要:首先分別在兩臺主機上將物理網(wǎng)口創(chuàng)建出兩個子接口。然后創(chuàng)建兩個子接口,一個作為網(wǎng)絡的網(wǎng)關,一個作為的網(wǎng)關。對子接口配置網(wǎng)關并啟用這樣之后再從和,就可以通了。 本文首發(fā)于我的公眾號 Linux云計算網(wǎng)絡(id: cloud_dev),專注于干貨分享,號內有 10T 書籍和視頻資源,后臺回復「1024」即可領取,歡迎大家關注,二維碼文末可以掃。 上一篇文章我們詳細介紹了 macvlan 這種...

    atinosun 評論0 收藏0
  • 網(wǎng)卡也能虛擬化?網(wǎng)卡虛擬化技術 macvlan 詳解

    摘要:通過不同的子接口,也能做到流量的隔離。會根據(jù)收到包的目的地址判斷這個包需要交給哪個虛擬網(wǎng)卡,虛擬網(wǎng)卡再把包交給上層的協(xié)議棧處理??偨Y是一種網(wǎng)卡虛擬化技術,能夠將一張網(wǎng)卡虛擬出多張網(wǎng)卡。 本文首發(fā)于我的公眾號 cloud_dev,專注于干貨分享,號內有大量書籍和視頻資源,后臺回復「1024」即可領取,歡迎大家關注,二維碼文末可以掃。 01 macvlan 簡介 前面的文章講過了幾種 Li...

    xiyang 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<