`
hjy2099
  • 浏览: 262716 次
  • 性别: Icon_minigender_1
  • 来自: 福州
社区版块
存档分类
最新评论

Linux服务器网络负载均衡的实现

阅读更多

保持服务器的高可用性是企业级IT 环境的重要因素,其中重要的一点是服务器网络连接的高可用性。利用服务器的网卡绑定技术有助于保证高可用特性并且提高网络性能。

在这里介绍一下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 的环境下实现的。网卡绑定的前提条件是确保两块网卡具有相同型号的独立芯片组。

# vi /etc/sysconfig/network-scripts/ ifcfg-bond0
[root@rhas root]# cp /etc/sysconfig/network-scripts/ifcfg-eth0 ifcfg-bond0

编辑虚拟网络接口配置文件,指定网卡IP地址。

# vi ifcfg-bond0
将第一行改成:DEVICE=bond0

# cat ifcfg-bond0
DEVICE=bond0
BOOTPROTO=static
IPADDR=172.31.0.13
NETMASK=255.255.252.0
BROADCAST=172.31.3.254
ONBOOT=yes
TYPE=Ethernet

这里要注意,不要指定单个网卡的IP 地址、子网掩码或网卡ID;将上述信息指定到虚拟适配器(Bonding)中即可。

[root@rhas network-scripts]# cat ifcfg-eth0
DEVICE=eth0
ONBOOT=yes
BOOTPROTO=dhcp
[root@rhas network-scripts]# cat ifcfg-eth1
DEVICE=eth0
ONBOOT=yes
BOOTPROTO=dhcp

# vi /etc/modules.conf

编辑 /etc/modules.conf 文件,加入如下两行内容,以使系统在启动时加载bonding 模块,对外虚拟网络接口设备bond0 。

alias bond0 bonding
options bond0 miimon=100 mode=1

说明:miimon 是用来进行链路监测的。如果miimon=100,那么系统每100ms 监测一次链路连接状态,如果有一条线路不通就转入另一条线路;mode 的值表 示工作模式,它共有0,1,2,3四种模式,常用的为0,1两种。

mode=0 表示load balancing (round-robin)为负载均衡方式,两块网卡都工作。
mode=1 表示fault tolerance (active-backup)提供冗余功能,工作方式是主备的工作方式,也就是说默认情况下只有一块网卡工作,另一块做备份。

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

# vi /etc/rc.d/rc.local

加入两行:
ifenslave bond0 eth0 eth1
route add -net 172.31.3.254 netmask 255.255.255.0 bond0

到此双网卡绑定已经配置完完成,重新启动服务器就会看到以下表示配置成功的信息了。

**********
Bringing up interface bond0 OK
Bringing up interface eth0 OK
Bringing up interface eth1 OK
**********

下面我们讨论一下mode 分别为0,1时的情况:

mode=1 工作在主备模式下,这时eth1 作为备份网卡是no arp 的:
[root@rhas network-scripts]# ifconfig 验证网卡的配置信息
bond0 Link encap:Ethernet HWaddr 00:0E:7F:25:D9:8B
inet addr:172.31.0.13 Bcast:172.31.3.255 Mask:255.255.252.0
UP BROADCAST RUNNING MASTER MULTICAST MTU:1500 Metric:1
RX packets:18495 errors:0 dropped:0 overruns:0 frame:0
TX packets:480 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:1587253 (1.5 Mb) TX bytes:89642 (87.5 Kb)


eth0 Link encap:Ethernet HWaddr 00:0E:7F:25:D9:8B
inet addr:172.31.0.13 Bcast:172.31.3.255 Mask:255.255.252.0
UP BROADCAST RUNNING SLAVE MULTICAST MTU:1500 Metric:1
RX packets:9572 errors:0 dropped:0 overruns:0 frame:0
TX packets:480 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:833514 (813.9 Kb) TX bytes:89642 (87.5 Kb)
Interrupt:11


eth1 Link encap:Ethernet HWaddr 00:0E:7F:25:D9:8B
inet addr:172.31.0.13 Bcast:172.31.3.255 Mask:255.255.252.0
UP BROADCAST RUNNING NOARP SLAVEMULTICAST MTU:1500 Metric:1
RX packets:8923 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:753739 (736.0 Kb) TX bytes:0 (0.0 b)
Interrupt:15

那也就是说在主备模式,当一个网络接口失效时(例如交换机掉电等),不会出现网络中断,系统会按照cat /etc/rc.d/rc.local 里指定网卡的顺序工作,机器仍能对外服务,起到了失效保护的功能。

在mode=0 负载均衡工作模式,它能提供两倍的带宽:

[root@rhas root]# ifconfig bond0 Link encap:Ethernet HWaddr 00:0E:7F:25:D9:8B
inet addr:172.31.0.13 Bcast:172.31.3.255 Mask:255.255.252.0
UP BROADCAST RUNNING MASTER MULTICAST MTU:1500 Metric:1
RX packets:2817 errors:0 dropped:0 overruns:0 frame:0
TX packets:95 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:226957 (221.6 Kb) TX bytes:15266 (14.9 Kb)

eth0 Link encap:Ethernet HWaddr 00:0E:7F:25:D9:8B
inet addr:172.31.0.13 Bcast:172.31.3.255 Mask:255.255.252.0
UP BROADCAST RUNNING SLAVE MULTICAST MTU:1500 Metric:1
RX packets:1406 errors:0 dropped:0 overruns:0 frame:0
TX packets:48 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:113967 (111.2 Kb) TX bytes:7268 (7.0 Kb)
Interrupt:11

eth1 Link encap:Ethernet HWaddr 00:0E:7F:25:D9:8B
inet addr:172.31.0.13 Bcast:172.31.3.255 Mask:255.255.252.0
UP BROADCAST RUNNING SLAVE MULTICAST MTU:1500 Metric:1
RX packets:1411 errors:0 dropped:0 overruns:0 frame:0
TX packets:47 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:112990 (110.3 Kb) TX bytes:7998 (7.8 Kb)
Interrupt:15

在这种情况下出现一块网卡失效,仅会是服务器出口带宽下降,也不会影响网络使用。通过查看bond0 的工作状态可以掌握bonding 的具体工作状态:

[root@rhas bonding]# cat /proc/net/bonding/bond0
bonding.c:v2.4.1 (September 15, 2003)

Bonding Mode: load balancing (round-robin)
MII Status: up
MII Polling Interval (ms): 0
Up Delay (ms): 0
Down Delay (ms): 0
Multicast Mode: all slaves

Slave Interface: eth1
MII Status: up
Link Failure Count: 0
Permanent HW addr: 00:0e:7f:25:d9:8a

Slave Interface: eth0
MII Status: up
Link Failure Count: 0
Permanent HW addr: 00:0e:7f:25:d9:8b

分享到:
评论

相关推荐

    负载均衡及服务器集群linux系统通用

    负载均衡和服务器集群是提高网络服务稳定性、可靠性和效率的关键技术。通过合理的架构设计和技术选型,可以有效地提升系统的整体性能和用户体验。未来随着云计算和分布式计算技术的发展,负载均衡技术还将进一步发展...

    基于Linux虚拟服务器的负载均衡

    【基于Linux虚拟服务器的负载均衡】是一种高效且经济的网络架构设计,用于在多台服务器之间分配网络流量,以确保高可用性和性能。这一技术在IT行业中被广泛应用,特别是在大型网站、云服务提供商以及需要处理大量...

    Linux服务器负载均衡的研究与实现.pdf

    "Linux服务器负载均衡的研究与实现" Linux服务器负载均衡是指通过某种负载分担技术将大量客户请求均匀分配到通过网络连接的一组服务器,由多个服务器并发响应客户请求、共同完成工作任务。负载均衡技术可以有效地...

    linux 服务器集群与负载均衡技术

    Linux服务器集群与负载均衡技术是构建高可用性、高性能计算环境的关键技术,广泛应用于大型网站、企业级应用和云计算服务中。本节将深入探讨这一主题,解析其核心概念、架构设计以及实施策略。 首先,我们需要理解...

    Linux环境下负载均衡集群的实现.pdf

    为了提高服务器的性能,作者提出了使用 Tomcat 和 Apache 在 Linux 环境下进行集成,实现负载均衡集群。作者分析了负载均衡集群的架构,详细阐述了方案的实现过程。 负载均衡集群的实现可以分为以下几个步骤: 1. ...

    linux下实现负载均衡

    在Linux环境下实现负载均衡,通常会使用到诸如LVS(Linux Virtual Server)这样的技术,它是一种高可用性集群解决方案,可以有效地将流量分发到多个服务器,提高系统的处理能力和响应速度,同时保证服务的连续性和...

    Linux服务器下多网卡负载均衡的研究 (1)

    综上所述,Linux服务器下多网卡的负载均衡是通过bonding技术实现的,通过不同算法来优化网络资源的使用和故障恢复。持续研究和改进这些算法有助于进一步提升服务器网络连接的可用性和性能,对于应对不断增长的网络...

    一种改进的Linux集群系统负载均衡算法.pdf

    本文提出了一种改进的Linux集群系统负载均衡算法,该算法通过修改负载权值计算指标,动态反馈机制来收集各个服务器的实时负载信息,然后根据权值选择最优服务器来处理新的任务。该算法可以提高整个系统的响应能力和...

    Linux配置DNS服务器及实现简单的负载均衡

    1.了解与认识Linux网络环境的配置,包括网卡、IP、网关、DNS等。 2.掌握Linux系统DNS服务器的配置和测试。 3.理解Linux系统DNS服务器配置的相关文件和字段的含义。...4.掌握基于DNS实现简单的负载均衡的方法。

    LVS实现网络负载均衡实例精讲

    ### LVS实现网络负载均衡实例精讲 #### 一、LVS概述与背景 随着互联网用户的快速增长,服务器面临着巨大的访问压力。特别是在1990年代末期至2000年代初期,随着互联网用户数量的急剧增加(例如,1998年全球互联网...

    Linux下的负载均衡集群LVS实现分析与测试.pdf

    Linux Virtual Server(LVS)是一种在Linux环境下实现的负载均衡技术,主要用于处理大规模并发访问的需求,通过将多台服务器组成集群来分担网络负载,从而提高整体的服务能力和可用性。其结构主要包括前端的负载均衡...

    Linux负载均衡集群技术在网络服务器中的应用.pdf

    Linux负载均衡集群技术在网络服务器中的应用主要体现在通过负载均衡技术来提高网络服务器的响应速度和处理能力,从而提升整个网络...同时,通过负载均衡,可以实现网络流量的监控和控制,从而提高网络服务的安全性。

    linux中的IP负载均衡实现原理.pdf

    Linux中的IP负载均衡实现原理主要涉及LVS(Linux Virtual Server)技术,这是一种高效且可扩展的解决方案,用于在集群环境中分配网络服务流量。LVS通过三层结构构建:负载调度器、服务器池和共享存储。 1. 负载调度...

    Linux下nginx负载均衡

    在IT行业中,Linux环境下的Nginx服务器因其高效、稳定和强大的反向代理及负载均衡功能而被广泛应用。本文将详细解析"Linux下Nginx负载均衡"这一主题,包括Nginx的基本概念、配置原理以及如何在Linux系统中设置负载...

    Linux下快速实现负载均衡.pdf

    Linux 下快速实现负载均衡 本文主要阐述如何在 Linux 系统下快速实现负载均衡,介绍了使用 LVS(Linux Virtual Server)搭建负载均衡集群的原理和实现方法。 一、负载均衡的定义和原理 负载均衡是指将外部请求分配...

    基于Linux的链路负载均衡技术研究与实现.pdf

    1. **配置多网络接口**:在Linux服务器上添加和配置多个网络接口,分别对应不同的Internet接入链路。 2. **设置策略路由**:通过内核路由表和规则,定义数据包根据不同条件(如目的地、源地址等)选择的出口链路。 ...

    linux下的负载均衡使用和配置

    在现代网络环境中,为了提高服务器的稳定性和网络带宽的利用率,负载均衡技术成为了一个重要的组成部分。本篇文章将详细介绍如何在Linux系统下通过双网卡绑定技术来实现负载均衡及失效保护,并提供具体的配置步骤。 ...

    Linux服务器下多网卡负载均衡的研究与实现.docx

    Linux 服务器下多网卡负载均衡的研究与实现 负载均衡技术在当前网络业务迅猛增加和升级硬件设施之间矛盾的一个有效措施,本文简单描述了关于负载均衡方面的研究现状,重点介绍了现今 Linux bonding 技术及其基于 ...

Global site tag (gtag.js) - Google Analytics