網絡組(Network Teaming)

網絡組(Network Teaming)
網絡組:是將多個網卡聚合在一起的方法,從而實現容錯和提高吞吐量
網絡組不同于舊版中bonding技術,提供更好的性能和擴展性
網絡組由內核驅動和teamd守護進程實現.
多種方式runner
    broadcast
    roundrobin
    activebackup
    loadbalance
    lacp (implements the 802.3ad Link Aggregation Control Protocol)
啟動team連接不會自動啟動網絡組中的team-slave連接
啟動網絡組中的team-slave連接不會自動啟動team連接
禁用team連接會自動禁用網絡組中的team-slave連接
沒有team-slave連接的team連接可以啟動靜態IP連接

啟用DHCP連接時,沒有team-slave連接的網絡組會等待team-slave連接的加入

創建team連接
nmcli con add type team [config <file>|<raw JSON data>] ifname <interface name> [con-name <connection name>]
    JSON格式指定runner方式:'{"runner": {"name": "METHOD"}}'
        METHOD := { broadcast|roundrobin|activebackup|loadbalance|lacp }

創建team-slave連接
nmcli con add type team-slave master <master (ifname, or connection UUID or name)> [config <file>|<raw JSON data>] ifname <interface name> [con-name <connection name>]
連接名<connection name>若不指定,默認為team-slave-ifname

管理網絡組配置文件
# /etc/sysconfig/network-scripts/ifcfg-team0-ens37
NAME=team0-ens37
UUID=80ea99c9-8d37-4a57-907f-1d5f7b3d420b
DEVICE=ens37
ONBOOT=yes
TEAM_MASTER=team0
DEVICETYPE=TeamPort

刪除網絡組配置:
teamdctl team0 state
nmcli connection show
nmcli connection down team0
nmcli connection delete team0-ens37
nmcli connection delete team0-ens38
nmcli connection delete team0
重新為網卡設備配置新的配置文件,以重用該網卡。
nmcli c add type ethernet ipv4.method manual ipv4.addresses 172.18.38.107/16 ipv4.gateway 172.18.0.1 ipv4.dns 8.8.8.8 ifname ens37 con-name ens37

實驗:創建網絡組
實驗環境:CentOS7,三塊網卡,其中額外一塊ens33網卡的IPADDR=172.18.38.102,PREFIX=16,GATEWAY=172.18.0.1,配置過程中ssh不斷網,方便操作。ens37和ens38兩塊網卡用作配置網絡組。
#要想執行nmcli命令,先啟動NetworkManager 服務:
systemctl start  NetworkManager
#查看網卡設備信息

ip link

網絡組(Network Teaming)
網絡組(Network Teaming)
#若即將配置為網絡組的網卡設備有IP,先清除之
ip a flush ens37
ip a flush ens38
網絡組(Network Teaming)
#添加連接:(type)類型team,(config)配置為活動-備用模式,(ifname) 設備名team0,(con-name)連接名team0
nmcli connection add type team config ‘{“runner”: {“name”: “activebackup”}}’ ifname team0 con-name team0
網絡組(Network Teaming)
#修改連接team0:(ipv4.method)配置手段為手動,ipv4.address,ipv4.gateway
nmcli connection modify team0 ipv4.method manual ipv4.addresses 172.18.38.103/16 ipv4.gateway 172.18.0.1
#如果此后再要修改team0的配置,必須先執行nmcli c down team0,再執行nmcli c up team0,修改才能生效。
#添加team-slave連接:(type)類型team-slave,(master)主設備名,(ifname)設備名必須對應網卡名,(con-name)連接名隨意起,缺省為team-slave-<ifname>
nmcli connection add type team-slave master team0 ifname ens37 con-name team0-ens37
nmcli connection add type team-slave master team0 ifname ens38 con-name team0-ens38
網絡組(Network Teaming)
#查看網絡組狀態
teamdctl team0 state
網絡組(Network Teaming)
#另外,執行nmcli c add命令時/etc/sysconfig/network-scripts目錄下會自動生成ifcfg-team0等網卡配置文件,所以即便重啟機器配置也不會丟失
網絡組(Network Teaming)
#配置完成后的最終狀態:
網絡組(Network Teaming)
網絡組(Network Teaming)
網絡組(Network Teaming)
網絡組(Network Teaming)


#驗證
#從內部通過team0的IP ping網關
ping -I 172.18.38.103 172.18.0.1
網絡組(Network Teaming)
#從外部(另一臺主機)ping team0 的IP地址
ping -I 172.18.38.102 172.18.38.7
網絡組(Network Teaming)
#設備斷開ens37,可查看狀態,活動slave接口變為ens38
nmcli dev disconnect ens37
teamdctl team0 state
網絡組(Network Teaming)
nmcli dev connect ens37     #連上ens37設備,此時不會自動切換slave活動接口,仍為ens38
teamdctl team0 stat     #題外話:這里ens37的down count并未加1,可能因為使用nmcli命令,它認為是管理性的操作,不計入故障。
網絡組(Network Teaming)
ip link set ens38 down     #再用ip link命令(和nmcli dev命令同樣工作在鏈路層)停用ens38設備,此時slave活動接口變為ens37
teamdctl team0 stat     #這里ens38的down count加1,說明它察覺到故障,自動切換接口到ens37上
網絡組(Network Teaming)
當然,也可以手動拔掉網線來驗證
整個驗證過程中ping一直有響應,說明網絡組工作正常。


#演示team連接與team-slave連接的關系
nmcli connection down team0     #停用網絡組team連接,會自動停用team-slave連接
nmcli c
nmcli connection up team0     #啟用網絡組team連接,并不會自動啟動啟用team-slave連接
nmcli c
nmcli connection up team0-ens37
nmcli c
nmcli connection up team0-ens38
nmcli c
teamdctl team0 state     #down count 計數歸零
網絡組(Network Teaming)


#移除網絡組
teamdctl team0 stat
nmcli c
nmcli c down team0
nmcli c del team0
nmcli c del team0-ens37
nmcli c del team0-ens38
#必要情況下重新為ens37和ens38網卡設備配置新的配置文件,以重用該網卡。
nmcli c add type ethernet ipv4.method manual ipv4.addresses 172.18.38.107/16 ipv4.gateway 172.18.0.1 ipv4.dns 8.8.8.8 ifname ens37 con-name ens37
網絡組(Network Teaming)

原創文章,作者:Leion,如若轉載,請注明出處:http://www.www58058.com/71856

(1)
LeionLeion
上一篇 2017-03-26
下一篇 2017-03-26

相關推薦

  • redis 主從復制實戰

    1.準備好4臺機器 192.168.42.150 redis-node1 #主 192.168.42.151 redis-node2 #從 192.168.42.152 redis-node3 #從 192.168.42.153 redis-node4 #從 將主機解析寫入hosts文件,分發至每臺機器 2.安裝redis,配置好基本配置 (1) 4臺機器,…

    Linux干貨 2017-07-18
  • 目錄,inode學習筆記

    目錄,inode學習筆記 1. 關于目錄,文件,數據塊 對于使用計算機的人而言,經常有一種 錯誤的認知:目錄(或者說,文件夾)里面存放著文件。實際上,目錄里面并不存放文件,以及文件數據。 實際上,目錄是一個特殊的文件,針對這個特殊的文件也存在一些特殊的規則,比如利用命令cp /dev/null <your directory>…

    Linux干貨 2017-04-01
  • 0803linux基礎小記

    讓普通用戶無法登錄: centos 6  touch /etc/nologin echo "wating" > /etc/nologin 普通用戶登錄時不能進入系統,有提示信息 centos7  touch /etc/nologin 或touch /run/nologin  chage -l …

    Linux干貨 2016-08-05
  • 文件查找與解壓縮

    文件查找 腳本文件名的查詢 which(尋找執行文件) which [-a] command -a :將所有由PATH目錄中可以找到的命令均列出,而不只是第一個被找到的命令名稱 文件名的查找 文件查找:實時查找:遍歷所有文件進行條件匹配;(find)非實時查找:根據索引查找;(whereis、locate) whereis whereis [-bmsu] […

    Linux干貨 2017-04-08
  • N25-第五周作業

    第五周作業 1、顯示當前系統上root、fedora或user1用戶的默認shell; grep "^\(root|fedora|user1\)" /etc/passwd | cut -d: -f7 2、找出/etc/rc.d/init.d/functions文件中某單詞后面跟一組小括號的行,形如:hello(); grep "…

    Linux干貨 2017-02-14
  • samba服務

    一、什么是SAMBA   Linux之間可以通過NFS服務方便的掛載遠程主機上的共享目錄,那么SAMBA主要是用于實現Windows主機與Linux主機之間共享文件互訪。它們之間的通信依賴于CIFS協議。 二、SAMBA使用的daemon     1、nmbd:在Linux上實現NetBIOS;     &n…

    Linux干貨 2016-02-14
欧美性久久久久