LINUX下双网卡绑定技术实现负载均衡和失效保护
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
保持服务器的高可用性是企业级 IT 环境的重要因素。其中最重要的一点是服务器网络连接的高可用性。网卡(NIC)绑定技术有助于保证高可用性特性并提供其它优势以提高网络性能。
我们在这介绍的Linux双网卡绑定实现就是使用两块网卡虚拟成为一块网卡,这个聚合起来的设备看起来是一个单独的以太网接口设备,通俗点讲就是两块网卡具有相同的IP地址而并行链接聚合成一个逻辑链路工作。其实这项技术在Sun和Cisco中早已存在,被称为Trunking和Etherchannel 技术,在Linux的2.4.x的内核中也采用这这种技术,被称为bonding。bonding技术的最早应用是在集群——beowulf上,为了提高集群节点间的数据传输而设计的。下面我们讨论一下bonding 的原理,什么是bonding需要从网卡的混杂(promisc)模式说起。我们知道,在正常情况下,网卡只接收目的硬件地址(MAC Address)是自身Mac的以太网帧,对于别的数据帧都滤掉,以减轻驱动程序的负担。但是网卡也支持另外一种被称为混杂promisc的模式,可以接收网络上所有的帧,比如说tcpdump,就是运行在这个模式下。bonding也运行在这个模式下,而且修改了驱动程序中的mac地址,将两块网卡的Mac地址改成相同,可以接收特定mac的数据帧。然后把相应的数据帧传送给bond驱动程序处理。
说了半天理论,其实配置很简单,一共四个步骤:
实验的操作系统是Redhat Linux Enterprise 3.0
绑定的前提条件:芯片组型号相同,而且网卡应该具备自己独立的BIOS芯片
双网卡邦定的拓朴图(见下图)
1. 1.编辑虚拟网络接口配置文件,指定网卡IP
2.vi /etc/sysconfig/ network-scripts/ ifcfg-bond0
3.[root@rhas-13 root]# cp /etc/sysconfig/network-scripts/ifcfg-eth0 ifcfg-bond0
4. 2 #vi ifcfg-bond0
5.将第一行改成 DEVICE=bond0
6.# cat ifcfg-bond0
7.DEVICE=bond0
8.BOOTPROTO=static
9.IPADDR=172.31.0.13
MASK=255.255.252.0
11.BROADCAST=172.31.3.254
12.ONBOOT=yes
13.TYPE=Ethernet
14.这里要主意,不要指定单个网卡的IP 地址、子网掩码或网卡 ID。将上述信息指定到虚拟适配器(bonding)中即可。
15.[root@rhas-13 network-scripts]# cat ifcfg-eth0
16.DEVICE=eth0
17.ONBOOT=yes
18.BOOTPROTO=dhcp
19.[root@rhas-13 network-scripts]# cat ifcfg-eth1
20.DEVICE=eth0
21.ONBOOT=yes
22.BOOTPROTO=dhcp
复制代码
3 # vi /etc/modules.conf “自己实验结果:centos文件为:/etc/modprobe.conf“
1.编辑 /etc/modules.conf 文件,加入如下一行内容,以使系统在启动时加载bonding模块,对外虚拟网络接口设备为 bond0
2.
3.加入下列两行
4.alias bond0 bonding
5.options bond0 miimon=100 mode=1
6.说明:miimon是用来进行链路监测的。比如:miimon=100,那么系统每100ms监测一次链路连接状态,如果有一条线路不通就转入另
一条线路;mode的值表示工作模式,他共有0,1,2,3四种模式,常用的为0,1两种。
7.mode=0表示load balancing (round-robin)为负载均衡方式,两块网卡都工作。
8.mode=1表示fault-tolerance (active-backup)提供冗余功能,工作方式是主备的工作方式,也就是说默认情况下只有一块网卡工作,
另一块做备份.
9.bonding只能提供链路监测,即从主机到交换机的链路是否接通。如果只是交换机对外的链路down掉了,而交换机本身并没有故障,
那么bonding会认为链路没有问题而继续使用
10. 4 # vi /etc/rc.d/rc.local
11.加入两行
1.ifenslave bond0 eth0 eth1
2.route add default gw 220.164.150.1
220.164.150.1 为我的网关,在应用中记得改为自己的网关
1.到这时已经配置完毕重新启动机器.
2.重启会看见以下信息就表示配置成功了
3.................
4.Bringing up interface bond0 OK
5.Bringing up interface eth0 OK
6.Bringing up interface eth1 OK
7.................
8.
9.下面我们讨论以下mode分别为0,1时的情况
10.
11.mode=1工作在主备模式下,这时eth1作为备份网卡是no arp的
12.[root@rhas-13 network-scripts]# ifconfig 验证网卡的配置信息
13.bond0 Link encap:Ethernet HWaddr 00:0E:7F:25:D9:8B
14.inet addr:172.31.0.13 Bcast:172.31.3.255 Mask:255.255.252.0
15.UP BROADCAST RUNNING MASTER MULTICAST MTU:1500 Metric:1
16.RX packets:18495 errors:0 dropped:0 overruns:0 frame:0
17.TX packets:480 errors:0 dropped:0 overruns:0 carrier:0
18.collisions:0 txqueuelen:0
19.RX bytes:1587253 (1.5 Mb) TX bytes:89642 (87.5 Kb)
20.
21.eth0 Link encap:Ethernet HWaddr 00:0E:7F:25:D9:8B
22.inet addr:172.31.0.13 Bcast:172.31.3.255 Mask:255.255.252.0
23.UP BROADCAST RUNNING SLAVE MULTICAST MTU:1500 Metric:1
24.RX packets:9572 errors:0 dropped:0 overruns:0 frame:0
25.TX packets:480 errors:0 dropped:0 overruns:0 carrier:0
26.collisions:0 txqueuelen:1000
27.RX bytes:833514 (813.9 Kb) TX bytes:89642 (87.5 Kb)
28.Interrupt:11
29.