Ubuntu从17.04开始,已经放弃在/etc/network/interfaces 里固定IP的配置,而是改成netplan方式,配置文件是:/etc/netplan/00-installer-config.yaml
官方文档:https://netplan.io/
1.单网卡静态IP地址
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
version: 2
ethernets:
ens33:
addresses:
- 10.0.0.70/8
gateway4: 10.0.0.254
nameservers:
addresses:
- 223.5.5.5
search:
- www.chsblogs.com
set paste #取消vim自动缩进功能
2.多网卡静态IP
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
version: 2
ethernets:
ens33:
addresses:
- 10.0.0.70/8
gateway4: 10.0.0.254
nameservers:
addresses:
- 223.5.5.5
search:
- www.chs.com
ens38:
addresses:
- 172.16.0.70/8
nameservers:
addresses:
- 223.5.5.5
routes:
- to: 172.0.0.0/8
via: 172.0.0.1
- to: 10.0.0.0/8
via: 10.0.0.254
3.单网卡桥接
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
version: 2
ethernets:
ens33:
dhcp4: no
dhcp6: no
bridges:
br0:
dhcp4: no
dhcp6: no
addresses: [10.0.0.70/8]
gateway4: 10.0.0.254
nameservers:
addresses: [223.5.5.5]
interfaces:
- ens33
4.多网卡桥接
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
version: 2
ethernets:
ens33:
dhcp4: no
dhcp6: no
ens38:
dhcp4: no
dhcp6: no
bridges:
br0:
dhcp4: no
dhcp6: no
addresses: [10.0.0.70/8]
gateway4: 10.0.0.254
nameservers:
addresses: [223.5.5.5]
interfaces:
- ens33
br1:
dhcp4: no
dhcp6: no
addresses: [172.0.0.70/8]
routes:
- to: 172.0.0.0/8
via: 172.0.0.1
- to: 10.0.0.0/8
via: 10.0.0.254
interfaces:
- ens38
5.双网卡绑定
加载bonding模块
modprobe -r bonding #可选择的操作,卸载模块
modprobe bonding #重载模块
lsmod|grep bonding #查看是否成功加载
cat /proc/net/bonding/bond0 #查看bond模式
七种bond模式说明
第⼀种模式:mod=0,即:(balance-rr) Round-robin policy(平衡抡循环策略)
特点:传输数据包顺序是依次传输(即:第1个包⾛eth0,下⼀个包就⾛eth1….⼀直循环下去,直到最后⼀个传输完毕),此模式提供负载平衡和容错能⼒。
第⼆种模式:mod=1,即: (active-backup) Active-backup policy(主-备份策略)
特点:只有⼀个设备处于活动状态,当⼀个宕掉另⼀个⻢上由备份转换为主设备。mac地址是外部可⻅得,从外⾯看来,bond的MAC地址是唯⼀的,以避免switch(交换机)发⽣混乱。此模式只提供了容错能⼒;由此可⻅此算法的优点是可以提供⾼⽹络连接的可⽤性,但是它的资源利⽤率较低,只有⼀个接⼝处于⼯作状态,在有 N 个⽹络接⼝的情况下,资源利⽤率为1/N。
第三种模式:mod=2,即:(balance-xor) XOR policy(平衡策略)
特点:基于指定的传输HASH策略传输数据包。缺省的策略是:(源MAC地址 XOR ⽬标MAC地址) % slave数量。其他的传输策略可以通过xmit_hash_policy选项指定,此模式提供负载平衡和容错能⼒。
第四种模式:mod=3,即:broadcast(⼴播策略)
特点:在每个slave接⼝上传输每个数据包,此模式提供了容错能⼒。
第五种模式:mod=4,即:(802.3ad) IEEE 802.3adDynamic link aggregation(IEEE 802.3ad 动态链接
聚合)
特点:创建⼀个聚合组,它们共享同样的速率和双⼯设定。根据802.3ad规范将多个slave⼯作在同⼀个激活的聚合体下。
必要条件:
条件1:ethtool⽀持获取每个slave的速率和双⼯设定。
条件2:switch(交换机)⽀持IEEE 802.3ad Dynamic link aggregation。
条件3:⼤多数switch(交换机)需要经过特定配置才能⽀持802.3ad模式。
第六种模式:mod=5,即:(balance-tlb) Adaptive transmit load balancing(适配器传输负载均衡)
特点:不需要任何特别的switch(交换机)⽀持的通道bonding。在每个slave上根据当前的负载(根据速度计算)分配外出流量。如果正在接受数据的slave出故障了,另⼀个slave接管失败的slave的MAC地址。该模式的必要条件:ethtool⽀持获取每个slave的速率
第七种模式:mod=6,即:(balance-alb) Adaptive load balancing(适配器适应性负载均衡)
特点:该模式包含了balance-tlb模式,同时加上针对IPV4流量的接收负载均衡(receive load balance,
rlb),⽽且不需要任何switch(交换机)的⽀持。
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
version: 2
ethernets:
ens33:
dhcp4: no
dhcp6: no
ens38:
dhcp4: no
dhcp6: no
bonds:
bond0:
interfaces:
- ens33
- ens38
addresses: [10.0.0.70/8]
gateway4: 10.0.0.254
nameservers:
addresses: [223.5.5.5]
parameters:
mode: active-backup
mii-monitor-interval: 100
6.双网卡绑定 & 桥接
网卡绑定用于提供网卡接口冗余以及高可用和端口聚合功能,桥接网卡再给需要桥接设备的服务使用。
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
version: 2
ethernets:
ens33:
dhcp4: no
dhcp6: no
ens38:
dhcp4: no
dhcp6: no
bonds:
bond0:
interfaces:
- ens33
- ens38
#addresses: [10.0.0.70/8]
#gateway4: 10.0.0.254
#nameservers:
# addresses: [223.5.5.5]
parameters:
mode: active-backup
mii-monitor-interval: 100
bridges:
br0:
dhcp4: no
dhcp6: no
addresses: [10.0.0.70/8]
gateway4: 10.0.0.254
nameservers:
addresses: [223.5.5.5]
interfaces:
- bond0
7.内网多网卡绑定
多网卡情况下实现网卡绑定
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
version: 2
ethernets:
ens33:
dhcp4: no
dhcp6: no
ens38:
dhcp4: no
dhcp6: no
ens39:
dhcp4: no
dhcp6: no
ens40:
dhcp4: no
dhcp6: no
bonds:
bond0:
interfaces:
- ens33
- ens38
addresses: [10.0.0.70/8]
gateway4: 10.0.0.254
nameservers:
addresses: [223.5.5.5]
parameters:
mode: active-backup
mii-monitor-interval: 100
bond1:
interfaces:
- ens39
- ens40
addresses: [172.0.0.70/8]
gateway4: 172.0.0.1
nameservers:
addresses: [223.5.5.5]
parameters:
mode: active-backup
mii-monitor-interval: 100
routes:
- to: 10.0.0.0/8
via: 10.0.0.254
- to: 172.0.0.0/8
via: 172.0.0.1
8.内网多网卡绑定 & 桥接
root@node70:~# vim /etc/netplan/00-installer-config.yaml
network:
version: 2
ethernets:
ens33:
dhcp4: no
dhcp6: no
ens38:
dhcp4: no
dhcp6: no
ens39:
dhcp4: no
dhcp6: no
ens40:
dhcp4: no
dhcp6: no
bonds:
bond0:
interfaces:
- ens33
- ens38
parameters:
mode: active-backup
mii-monitor-interval: 100
bond1:
interfaces:
- ens39
- ens40
parameters:
mode: active-backup
mii-monitor-interval: 100
bridges:
br0:
dhcp4: no
dhcp6: no
addresses: [10.0.0.70/8]
gateway4: 10.0.0.254
nameservers:
addresses: [223.5.5.5]
interfaces:
- bond0
br1:
dhcp4: no
dhcp6: no
addresses: [172.0.0.70/8]
gateway4: 172.0.0.1
nameservers:
addresses: [223.5.5.5]
interfaces:
- bond1
routes:
- to: 10.0.0.0/8
via: 10.0.0.254
- to: 172.0.0.0/8
via: 172.0.0.1