作者:北南南北
来自:oklinux
摘要:如何把多个网卡绑定成为一个网卡,并且指定为一个IP地址,解决网络负载问题;本文在Slackware Linux系统进行实例进行解说实现的方法,希望对新手弟兄在解决网络负载问题过程中有点帮助;
目录
1. 什么是bonding;
2.bonding 应用方向;
3. 网络负载均衡应用实例;
3.1 系统环境及实现目标;
3.2 对于System V的风格Linux系统的解决办法;
3.3 在Slackware下通过bonding来实现网络负载均衡;
3.31 判定内核版本;
3.32 编译bonding;
3.33 编译 ifenslave ;
3.34 修改网络相关配置文件;
3.35 尝试绑定多个网卡为一个设备bond0;
4. 关于本文;
5. 更新日志;
6. 参考文档;
7.相关文档;
正文
1. 什么是bonding;
Linux bonding 驱动提供了一个把多个网络接口设备捆绑为单个的网络接口设置来使用,用于网络负载均衡及网络冗余。
The Linux bonding driver provides a method for aggregating multiple network interfaces into a single logical bonded interface. The behavior of the bonded interfaces depends upon the mode; generally speaking, modes provide either hot standby or load balancing services. Additionally, link integrity monitoring may be performed.
2.bonding 应用方向;
2.1 网络负载均衡;
对于bonding的网络负载均衡是我们在文件服务器中常用到的,比如把三块网卡,当做一块来用,解决一个IP地址,流量过大,服务器网络压力过大的问题。对于文件服务器来说,比如NFS或SAMBA文件服务器,没有任何一个治理员会把内部网的文件服务器的IP地址弄很多个来解决网络负载的问题。假如在内网中,文件服务器为了治理和应用上的方便,大多是用同一个IP地址。对于一个百M的本地网络来说,文件服务器在多个用户同时使用的情况下,网络压力是极大的,非凡是SAMABA和NFS服务器。为了解决同一个IP地址,突破流量的限制,究竟网线和网卡对数据的吞吐量是有限制的。假如在有限的资源的情况下,实现网络负载均衡,最好的办法就是 bonding ;
2.2 网络冗余;
对于服务器来说,网络设备的稳定也是比较重要的,非凡是网卡。在生产型的系统中,网卡的可靠性就更为重要了。在生产型的系统中,大多通过硬件设备的冗余来提供服务器的可靠性和安全性,比如电源。bonding 也能为网卡提供冗余的支持。把网个网卡绑定到一个IP地址,当一块网卡发生物理性损坏的情况下,另一块网卡也能提供正常的服务。
3. 网络负载均衡应用实例;
3.1 系统环境及实现目标 ;
操作系统环境:Slackware 11.0,内核 2.6.20
网卡:三张;
实现目标:让三张网卡eth0、eth1、eth2 绑定为一张,实现网络负载均衡。
通过Google能找到好多bonding的文档,但大多是洋文的,国内也有一篇吧,好象是在Redhat/Fedora环境下的应用,也就是说对于System V风格的init脚本启动脚本的。对于BSD风格的启动服务的脚本的Linux操作系统,网上并没有太多的现成文档。对于Debian 、Fedora、Redhat、Ubuntu都是System V风格的。
对于Slackware来说则是BSD-like风格的。除了在Slackware的官方文档中,提到bonding的用法以外,网上的文档比较少。我为此走了不少弯路。最主要的原因是我还是没读懂Slackware,虽然Slackware用起来简单,但假如不读文档,一样解决不了问题。看来官方文档对我来说是多么重要了,假如你解决不了呢?是不是也和我一样不去读DOC?假如和我一样,还是象我一样,老老实实的读官方DOC吧,只要是应用的问题,大多是可以解决的。
3.2 对于System V的风格Linux系统的解决办法;
对于Debian 、Fedora、Redhat、Ubuntu都是System V风格的系统,您可以参考 《Bonding》
3.3 在Slackware下通过bonding来实现网络负载均衡;
本文主要是解决网络负载均衡,并非是通过bonding 来实现到网络设备冗余的实现;
3.31 判定内核版本;
[root@linuxsir:/home/beinan#] uname -a
Linux linuxsir 2.6.20 #7 SMP Sun May 6 00:20:14 CST 2007 x86_64 x86_64 x86_64 GNU/Linux
根本内核版本来安装您的内核源码包,一般发行版都有提供。安装好后,一般是放在/usr/src目录中。假如您是自己编译的,你应该知道你的源码包放的位置;比如我把源码包放在了 /usr/src/linux-2.6.20。
3.32 编译bonding;
bonding 是需要编译才能用的,Linux的内核默认是否已经支持了,可以通过 modinfo bonding 来查看;
[root@linuxsir:/home/beinan#] /sbin/modinfo modinfo
假如没有具体的信息输出,可能就不支持了,您应该自己编译;要把Bonding driver support以模块方式编译; 内核编译方法,请参考《》
挂载bonding 模块的方法;
[root@linuxsir:/home/beinan#] modprobe bonding
3.33 编译 ifenslave ;
在Linux 比较新的内核中,ifenslave 并不是默认被内核支持的,需要我们自己编译;我们要进入内核源码包中类似如下的位置;
[root@linuxsir:/home/beinan#] cd /usr/src/linux-2.6.20/Documentation/networking
[root@linuxsir:/home/networking#] gcc -Wall -Wstrict-prototypes -O -I/usr/src/linux-2.6.20/include ifenslave.c -o ifenslave
[root@linuxsir:/home/networking#] cp ifenslave /sbin/ifenslave
3.34 修改网络相关配置文件;
在Slackware 中,我们首先要修改 /etc/rc.d/rc.inet 文件;找到 如下一行;
. /etc/rc.d/rc.inet1.conf
加入下面一段;
# bonding conf
/sbin/ifenslave bond0 eth0
/sbin/ifenslave bond0 eth1
/sbin/ifenslave bond0 eth2
共3页: 上一页 1 [2] [3] 下一页