KVM虚拟化网桥搭建
Linux环境部署KVM虚拟化平台,系统版本centos7.6,GUI桌面以及虚拟化支持(安装时)。
Bridge基本原理
一般来说,KVM客户机有两种网络连接方式:NAT与Bridge。
NAT方式:让虚拟机访问主机、互联网或本地网络上的资源的简单方法,但是不能从网络或其他的客户机访问客户机,性能上也需要大的调整。
Virtual Bridge:这种方式要比用户网络复杂一些,但是设置好后客户机与互联网,客户机与主机之间的通信都很容易。客户机和子网里面的机器能够互相通信。可以使虚拟机成为网络中具有独立IP的主机。
桥接网络(也叫物理设备共享)被用作把一个物理设备复制到一台虚拟机。
网络虚拟化是虚拟化技术中最复杂的部分,也是非常重要的资源。
单Vlan Bridge创建步骤
在eno3上搭建一座Bridge=breno3,此桥的所有流量均从eno3发送,KVM虚拟机网络挂载到breno3上即可进行网络访问,breno3所在vlan和eno3所在vlan一致。
原理图:
试验使用ifcfg-eno3网口, 进入网络配置目录:cd /etc/sysconfig/network-scripts
文件可直接创建 或者使用命令创建
1 | 1 创建网桥 |
修改物理端口
1 | [root@node1 network-scripts]# vi ifcfg-eno3 |
添加对应Birdge
1 | [root@node1 network-scripts]# vi ifcfg-breno3 |
重启网络,查看
经过检测,KVM虚拟机可正常访问网络
1 | service network restart |
多Vlan Bridge创建步骤
一个Vlan为一个网段,同一台机器上的虚拟机可能归属不同的vlan,此时需要在宿主机创建多个vlan,将各个虚拟机划分到不同的vlan下,虚机产生的流量将带上不同vlan标识。
注意:eno5在交换机端更改为trunk口,宿主机用软件实现了一个交换机
原理图:
创建端口vlan
创建vlan10 同理可创建vlan12
1 | [root@node1 network-scripts]# vi ifcfg-eno5.10 |
创建brvlan-10
1 | [root@node1 network-scripts]# cat ifcfg-brvlan-10 |
重启网络,查看
经过检测,KVM虚拟机挂载到对应vlan下,可正常访问网络
1 | service network restart |
网卡绑定bond
网卡bond(绑定),也称作网卡捆绑。就是将两个或者更多的物理网卡绑定成一个虚拟网卡。
网卡绑定的目的:
1.提高网卡的吞吐量。
2.增强网络的高可用,同时也能实现负载均衡。
网卡配置 bond (绑定)bond模式:
(1)Mode=0(balance-rr) 表示负载分担round-robin,平衡轮询策略,具有负载平衡和容错功能bond的网卡MAC为当前活动的网卡的MAC地址,需要交换机设置聚合模式,将多个网卡绑定为一条链路。
(2)Mode=1(active-backup) 表示主备模式,具有容错功能,只有一块网卡是active,另外一块是备的standby,这时如果交换机配的是捆绑,将不能正常工作,因为交换机往两块网卡发包,有一半包是丢弃的。
(3)Mode=2(balance-xor) 表示XOR Hash负载分担(异或平衡策略),具有负载平衡和容错功能每个slave接口传输每个数据包和交换机的聚合强制不协商方式配合。(需要xmit_hash_policy)。
(4)Mode=3(broadcast) 表示所有包从所有interface发出,广播策略,具有容错能力,这个不均衡,只有冗余机制…和交换机的聚合强制不协商方式配合。
(5)Mode=4(802.3ad) 表示支持802.3ad协议(IEEE802.3ad 动态链接聚合) 和交换机的聚合LACP方式配合(需要xmit_hash_policy)。
(6)Mode=5(balance-tlb) 适配器传输负载均衡,并行发送,无法并行接收,解决了数据发送的瓶颈。 是根据每个slave的负载情况选择slave进行发送,接收时使用当前轮到的slave。
(7)Mode=6(balance-alb) 在5的tlb基础上增加了rlb。适配器负载均衡模式并行发送,并行接收数据包。
5和6不需要交换机端的设置,网卡能自动聚合。4需要支持802.3ad。0,2和3理论上需要静态聚合方式,但实测中0可以通过mac地址欺骗的方式在交换机不设置的情况下不太均衡地进行接收。
常用的有三种
mode=0:平衡负载模式,有自动备援,但需要”Switch”支援及设定。
mode=1:自动备援模式,其中一条线若断线,其他线路将会自动备援。
mode=6:平衡负载模式,有自动备援,不必”Switch”支援及设定。
原理图:
更改端口配置
首先更改eno4配置,绑定到bond6; 同理,其他端口可同样操作(对应交换机为trunk,否则vlan之间无法通信)
1 | [root@node1 network-scripts]# vi ifcfg-eno4 |
创建master=bond0
网卡绑定模式
1 | [root@node1 network-scripts]# vi ifcfg-bond6 |
搭建桥br6
1 | [root@node1 network-scripts]# cat ifcfg-br6 |
查看bond状态
可查看当前所使用端口
1 | [root@node1 network-scripts]# cat /proc/net/bonding/bond6 |
链路绑定完成
创建不同vlan10 同理创建vlan12
1 | [root@node1 network-scripts]# vi ifcfg-br6.10 |
重启网络,并查看状态
1 | [root@node1 network-scripts]# systemctl restart network |
虚机的挂在vlan
1 | brctl addif brvlan-10 vnet0 |
至此,环境搭建完毕,链路聚合,并且划分了不同的vlan