linux多网卡绑定聚合——bond技术

 将多个Linux网络端口绑定为一个,可以提升网络的性能,比如对于备份服务器,需要在一个晚上备份几个T的数据,如果使用单个的千兆网口将会是很严重的瓶颈。其它的应用,比如ftp服务器,高负载的下载网站, 都有类似的问题。因此使用Linux teaming或bond来绑定多个网卡作为一个逻辑网口,配置单个的IP地址,会大幅提升服务器的网络吞吐(I/O)。  

  Linux的多网卡绑定功能使用的是内核中的"bonding"模块,关于此模块可以参考Linux Ethernet Bonding Driver文档, 但是目前发布各个Linux版本内核均已包含了此模块,大多数情况下不需要重新编译内核。 Linux 的 bonding 驱动提供了绑定/集成(bond)多个网卡为一个虚拟逻辑网口的功能。并请注意绑定的网口(bonded)有多种工作模式; 一般来说,分为热后备(hot standby) 和负载均衡(load balancing). 在Redhat/Fedora和其它类Redhat Linux中是比较容易配置的。

1.创建bond0配置文件(注意大小写)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
vi /etc/sysconfig/network-scripts/ifcfg-bond0  
DEVICE=bond0             --物理设备名字 
NAME=bond0
TYPE=Bond
BONDING_MASTER=yes
IPADDR=192.168.1.1          --IP地址 
NETMASK=255.255.255.0         --子网掩码 
NETWORK=192.168.1.0          --所属子网 
BROADCAST=192.168.1.255          --广播地址 
GATEWAY=192.168.1.254          --网关 
ONBOOT=yes                --随机启动 
BOOTPROTO=none  
USERCTL=no                 --是否允许非root用户控制该设备
BONDING_OPTS="mode=1 miimon=100"

2.修改被绑定的eth0和eth1的配置文件(注意大小写) 

1
2
3
4
5
6
7
8
9
vi /etc/sysconfig/network-scripts/ifcfg-eth0        #针对不同的服务器,可以为em1或ens6f0
TYPE=Ethernet  
DEVICE=eth0                                           
BOOTPROTO=none   
ONBOOT=yes 
USERCTL=no 
MASTER=bond0    
SLAVE=yes      
#HWADDR=00:15:17:CC:FC:35

eth1的配置文件与之相同,只是device的值改为eth1即可。

3.装在bond模块驱动

编辑/etc/modprobe.conf或者/etc/modules.conf文件,加入如下内容,使系统启动时加载bonding模块驱动 (如果没有文件,则手动创建) 

1
2
3
vi /etc/modules.conf
alias bond0 bonding  
options bond0 miimon=100 mode=1

4.验证是否成功做到了冗余的效果:

ifdown eth0或者ifdown eth1,然后ping 192.168.1.1


  说明: 

  1).miimon=100 用来进行链路监测的。即每100ms监测一次链路状态,如果有一条线路不通就转入另一条线路。bonding只监测主机与交换机之间链路。如  果交换机出去的链路出问题而本身没有问题,那么bonding认为链路没有问题而继续使用。 

  2).mode=1 表示提供冗余功能。除此之外还可以为0、2、3,共四种模式。0表示负载均衡  

  mode的值表示工作模式,他共有0,1,2,3四种模式,常用的为0,1两种。需根据交换机可提供的工作模式选择。  

  mode=0表示load balancing (round-robin)为负载均衡方式,两块网卡都工作。  

  mode=1表示fault-tolerance (active-backup)提供冗余功能,工作方式是主备的工作方式,也就是说默认情况下只有一块网卡工作,另一块做备份。

 引用 

  a、bonding只能提供链路监测,即从主机到交换机的链路是否接通。如果只是交换机对外的链路down掉了,而交换机本身并没有故障,那么bonding会认   为链路没有问题而继续使用。 

  b、设置的模式要与交换机设置的模式一致。

4.在/etc/rc.d/rc.local文件中加入如下语句,使得系统启动自动运行  

ifenslave bond0 eth0 eth1 

route add -net 192.168.1.254 netmask 255.255.255.0  bond0    #如有需要才加该路由  

5.检测、验证配置 

首先执行命令装载bonding模块:modprobe bonding 

重启网络服务,并确认bond0正确启动:service network restart 

确认设备已经正确加载:less /proc/net/bonding/bond0 

列出所有网口:ifconfig  

至此,bond 的设置就基本结束了



本文转自 Mr_sheng 51CTO博客,原文链接:http://blog.51cto.com/sf1314/2071140

上一篇:快速进入大项目开发状态的思考


下一篇:使用for循环遍历文件、使用while循环遍历文件