`

LVS(Linux Virtual Server) 学习笔记

 
阅读更多

LVS(Linux Virtual Server) 学习笔记

1.LVS简介

最近学习了LVS(Linux Virtual Server)的集群技术,把搜集的一些资料整理一下。LVS(Linux Virtual Server)其实就是针对高可伸缩、高可用网络服务的需求,给出了基于IP层和基于内容请求分发的负载平衡调度解决方法,并在Linux内核中实现了这些方法,将一组服务器构成一个实现可伸缩的、高可用网络服务的虚拟服务器。
所以,lvs需要内核有ipvs支持,确保你的内核支持ipvs后,只需安装ipvsadm就可以把一台服务器配置成负载调度器(Load Balancer)。对外提供服务的IP,也就是我们访问的IP称做VIP。调度器LB的任务主要是分发请求,真正处理的是真实服务器(Real Server)。这就是LVS工作的基本方式和一些基本术语,下面是一张结构图。

负载调度器(load balancer):它是整个集群对外面的前端机,负责将客户的请求发送到一组服务器上执行,而客户认为服务是来自一个IP地址(我们可称之为虚拟IP地址)上的。
服务器池(server pool):是一组真正执行客户请求的服务器,执行的服务有WEB、MAIL、FTP和DNS等。
共享存储(shared storage):它为服务器池提供一个共享的存储区,这样很容易使得服务器池拥有相同的内容,提供相同的服务。

2.IP虚拟服务器软件IPVS

IPVS软件实现了这三种IP负载均衡技术,它们的大致原理如下:

Virtual Server via Network Address Translation(VS/NAT)


通过网络地址转换,调度器重写请求报文的目标地址,根据预设的调度算法,将请求分派给后端的真实服务器;真实服务器的响应报文通过调度器时,报文的源地址被重写,再返回给客户,完成整个负载调度过程。

Virtual Server via IP Tunneling(VS/TUN)

采用NAT技术时,由于请求和响应报文都必须经过调度器地址重写,当客户请求越来越多时,调度器的处理能力将成为瓶颈。为了解决这个问题,调度器把请求报 文通过IP隧道转发至真实服务器,而真实服务器将响应直接返回给客户,所以调度器只处理请求报文。由于一般网络服务应答比请求报文大许多,采用 VS/TUN技术后,集群系统的最大吞吐量可以提高10倍。

Virtual Server via Direct Routing(VS/DR)

VS/DR通过改写请求报文的MAC地址,将请求发送到真实服务器,而真实服务器将响应直接返回给客户。同VS/TUN技术一样,VS/DR技术可极大地 提高集群系统的伸缩性。这种方法没有IP隧道的开销,对集群中的真实服务器也没有必须支持IP隧道协议的要求,但是要求调度器与真实服务器都有一块网卡连 在同一物理网段上。

三种IP负载均衡技术的优缺点比较:
杂项         VS/NAT     VS/TUN      VS/DR
服务器操作系统    任意      支持隧道     多数(支持Non-arp )
服务器网络      私有网络    局域网/广域网   局域网
服务器数目(100M网络) 10-20      100        多(100)
服务器网关      负载均衡器   自己的路由    自己的路由
效率         一般      高        最高

针对不同的网络服务需求和服务器配置,IPVS调度器实现了如下八种负载调度算法:
轮叫(Round Robin)
调度器通过”轮叫”调度算法将外部请求按顺序轮流分配到集群中的真实服务器上,它均等地对待每一台服务器,而不管服务器上实际的连接数和系统负载。

加权轮叫(Weighted Round Robin)
调度器通过”加权轮叫”调度算法根据真实服务器的不同处理能力来调度访问请求。这样可以保证处理能力强的服务器处理更多的访问流量。调度器可以自动问询真实服务器的负载情况,并动态地调整其权值。

最少链接(Least Connections)
调度器通过”最少连接”调度算法动态地将网络请求调度到已建立的链接数最少的服务器上。如果集群系统的真实服务器具有相近的系统性能,采用”最小连接”调度算法可以较好地均衡负载。

加权最少链接(Weighted Least Connections)
在集群系统中的服务器性能差异较大的情况下,调度器采用”加权最少链接”调度算法优化负载均衡性能,具有较高权值的服务器将承受较大比例的活动连接负载。调度器可以自动问询真实服务器的负载情况,并动态地调整其权值。

基于局部性的最少链接(Locality-Based Least Connections)
“基于局部性的最少链接” 调度算法是针对目标IP地址的负载均衡,目前主要用于Cache集群系统。该算法根据请求的目标IP地址找出该目标IP地址最近使用的服务器,若该服务器 是可用的且没有超载,将请求发送到该服务器;若服务器不存在,或者该服务器超载且有服务器处于一半的工作负载,则用”最少链接”的原则选出一个可用的服务 器,将请求发送到该服务器。

带复制的基于局部性最少链接(Locality-Based Least Connections with Replication)
“带复制的基于局部性最少链接”调度算法也是针对目标IP地址的负载均衡,目前主要用于Cache集群系统。它与LBLC算法的不同之处是它要维护从一个 目标IP地址到一组服务器的映射,而LBLC算法维护从一个目标IP地址到一台服务器的映射。该算法根据请求的目标IP地址找出该目标IP地址对应的服务 器组,按”最小连接”原则从服务器组中选出一台服务器,若服务器没有超载,将请求发送到该服务器,若服务器超载;则按”最小连接”原则从这个集群中选出一 台服务器,将该服务器加入到服务器组中,将请求发送到该服务器。同时,当该服务器组有一段时间没有被修改,将最忙的服务器从服务器组中删除,以降低复制的 程度。

目标地址散列(Destination Hashing)
“目标地址散列”调度算法根据请求的目标IP地址,作为散列键(Hash Key)从静态分配的散列表找出对应的服务器,若该服务器是可用的且未超载,将请求发送到该服务器,否则返回空。

源地址散列(Source Hashing)
“源地址散列”调度算法根据请求的源IP地址,作为散列键(Hash Key)从静态分配的散列表找出对应的服务器,若该服务器是可用的且未超载,将请求发送到该服务器,否则返回空。

3.实现VS/NAT

环境:LB:ipvsadm,RS:LAMP
ipvsadm可以到官网下载安装:http://www.linuxvirtualserver.org/software/index.html;LAMP安装省略,网上资料很多。
VIP:192.168.1.100
LB:10.3.37.100
RS:10.3.37.101
RS:10.3.37.102
RS:10.3.37.103
RS:10.3.37.104

LB配置:
外部地址为192.168.1.100 内部地址为10.3.37.100,LVS在VS/NAT、VS/DR和VS/TUN3种方式下均需要打开ip_forward功能。

vi /etc/sysctl.conf  
#加入一行  
net.ipv4.ip_forward = 1  
#退出编辑,执行sysctl -p使配置生效。  
sysctl -p  

ipvs的脚本(ipvsadin详解见下文)

复制代码
#!/bin/sh  
  
ipvsadm -C  
ipvsadm -A -t 192.168.1.100:80 -s wlc  
ipvsadm -a -t 192.168.1.100:80 -r 10.3.37.101:80 -m  
ipvsadm -a -t 192.168.1.100:80 -r 10.3.37.102:80 -m  
ipvsadm -a -t 192.168.1.100:80 -r 10.3.37.103:80 -m  
ipvsadm -a -t 192.168.1.100:80 -r 10.3.37.104:80 -m  
复制代码

RealServer的配置(网关设置成BL内网IP:10.3.37.100):
网关配置(/etc/sysconfig/network 文件的内容如下)

NETWORKING=yes  
HOSTNAME=localhost.localdomain  
GATEWAY=10.3.37.100  

网卡配置文件(/etc/sysconfig/network-scripts/ifcfg-eth0的内容如下)

DEVICE=eth0  
ONBOOT=yes  
BOOTPROTO=static  
IPADDR=10.3.37.101  
NETMASK=255.255.255.0  
BROADCAST=10.3.37.255  

4.实现VS/DR

只要知道了原理和ipvsadm基本使用,配置和VS/NAT没多大差别,关键在于RS上要关闭arp。
RealServer的配置:

复制代码
vi /etc/sysctl.conf  
#加入一行  
net.ipv4.ip_forward = 1  
net.ipv4.conf.lo.arp_ignore = 1  
net.ipv4.conf.lo.arp_announce = 2  
net.ipv4.conf.all.arp_ignore = 1  
net.ipv4.conf.all.arp_announce = 2  
#退出编辑,执行sysctl -p使配置生效。  
sysctl -p  
复制代码

5.ipvsadm详解

复制代码
 1 1,virtual-service-address:是指虚拟服务器的ip 地址  
 2 2,real-service-address:是指真实服务器的ip 地址  
 3 3,scheduler:调度方法  
 4 (lna@networksbase.com 翻译 ipvsadm v1.21 2004 年4 月)  
 5 ipvsadm 的用法和格式如下:  
 6 ipvsadm -A|E -t|u|f virutal-service-address:port [-s scheduler] [-p  
 7 [timeout]] [-M netmask]  
 8 ipvsadm -D -t|u|f virtual-service-address  
 9 ipvsadm -C  
10 ipvsadm -R  
11 ipvsadm -S [-n]  
12 ipvsadm -a|e -t|u|f service-address:port -r real-server-address:port  
13 [-g|i|m] [-w weight]  
14 ipvsadm -d -t|u|f service-address -r server-address  
15 ipvsadm -L|l [options]  
16 ipvsadm -Z [-t|u|f service-address]  
17 ipvsadm --set tcp tcpfin udp  
18 ipvsadm --start-daemon state [--mcast-interface interface]  
19 ipvsadm --stop-daemon  
20 ipvsadm -h  
21 命令选项解释:  
22 有两种命令选项格式,长的和短的,具有相同的意思。在实际使用时,两种都可  
23 以。  
24 -A --add-service 在内核的虚拟服务器表中添加一条新的虚拟服务器记录。也  
25 就是增加一台新的虚拟服务器。  
26 -E --edit-service 编辑内核虚拟服务器表中的一条虚拟服务器记录。  
27 -D --delete-service 删除内核虚拟服务器表中的一条虚拟服务器记录。  
28 -C --clear 清除内核虚拟服务器表中的所有记录。  
29 -R --restore 恢复虚拟服务器规则  
30 -S --save 保存虚拟服务器规则,输出为-R 选项可读的格式  
31 -a --add-server 在内核虚拟服务器表的一条记录里添加一条新的真实服务器  
32 记录。也就是在一个虚拟服务器中增加一台新的真实服务器  
33 -e --edit-server 编辑一条虚拟服务器记录中的某条真实服务器记录  
34 -d --delete-server 删除一条虚拟服务器记录中的某条真实服务器记录  
35 -L|-l --list 显示内核虚拟服务器表  
36 -Z --zero 虚拟服务表计数器清零(清空当前的连接数量等)  
37 --set tcp tcpfin udp 设置连接超时值  
38 --start-daemon 启动同步守护进程。他后面可以是master 或backup,用来说  
39 明LVS Router 是master 或是backup。在这个功能上也可以采用keepalived 的  
40 VRRP 功能。  
41 --stop-daemon 停止同步守护进程  
42 -h --help 显示帮助信息  
43 其他的选项:  
44 -t --tcp-service service-address 说明虚拟服务器提供的是tcp 的服务  
45 [vip:port] or [real-server-ip:port]  
46 -u --udp-service service-address 说明虚拟服务器提供的是udp 的服务  
47 [vip:port] or [real-server-ip:port]  
48 -f --fwmark-service fwmark 说明是经过iptables 标记过的服务类型。  
49 -s --scheduler scheduler 使用的调度算法,有这样几个选项  
50 rr|wrr|lc|wlc|lblc|lblcr|dh|sh|sed|nq,  
51 默认的调度算法是: wlc.  
52 -p --persistent [timeout] 持久稳固的服务。这个选项的意思是来自同一个客  
53 户的多次请求,将被同一台真实的服务器处理。timeout 的默认值为300 秒。  
54 -M --netmask netmask persistent granularity mask  
55 -r --real-server server-address 真实的服务器[Real-Server:port]  
56 -g --gatewaying 指定LVS 的工作模式为直接路由模式(也是LVS 默认的模式)  
57 -i --ipip 指定LVS 的工作模式为隧道模式  
58 -m --masquerading 指定LVS 的工作模式为NAT 模式  
59 -w --weight weight 真实服务器的权值  
60 --mcast-interface interface 指定组播的同步接口  
61 -c --connection 显示LVS 目前的连接 如:ipvsadm -L -c  
62 --timeout 显示tcp tcpfin udp 的timeout 值 如:ipvsadm -L --timeout  
63 --daemon 显示同步守护进程状态  
64 --stats 显示统计信息  
65 --rate 显示速率信息  
66 --sort 对虚拟服务器和真实服务器排序输出  
67 --numeric -n 输出IP 地址和端口的数字形式  
复制代码

分享到:
评论

相关推荐

    linux virtual server 概述

    Linux Virtual Server(LVS)是一种高效且可扩展的负载均衡解决方案,主要用于构建高可用性和高性能的服务器集群。LVS的核心思想是将多个物理服务器合并成一个逻辑上的虚拟服务器,为客户提供无缝的服务体验,同时...

    2.LVS(Linux Virtual Server)集群项目实践.pdf

    ### LVS(Linux Virtual Server)集群项目实践 #### 一、LVS系统模型 Linux虚拟服务器(Linux Virtual Server, LVS)是一种构建于实际服务器集群之上的解决方案,它对外表现为单一的服务实体,即用户只能看到作为...

    lvs Virtual_Server_Administration lvs pdf

    LVS(Linux Virtual Server)是一种利用特殊的路由和负载均衡技术来提供高效服务的解决方案,特别适用于生产环境。书中通过PIRANHA工具详细介绍了LVS的配置过程,以及如何使用Red Hat Enterprise Linux 5.2进行高...

    Linux Virtual Server

    ### Linux Virtual Server (LVS) 知识点详解 #### 一、概述 **Linux Virtual Server**(简称 LVS)是一种构建在 Linux 平台上的负载均衡解决方案,它通过智能调度算法来分配网络请求到后端的真实服务器上,从而...

    Red Hat Enterprise Linux 5 Virtual Server Administration

    Red Hat Enterprise Linux 5 Virtual Server Administration是Red Hat官方发布的一份关于Linux Virtual Server (LVS)的管理指南,旨在帮助管理员更好地管理和维护Red Hat Enterprise Linux 5系统中的虚拟服务器。...

    LVS(Linux Virtual Server)Linux 虚拟服务器介绍及配置(负载均衡系统)

    LVS(Linux Virtual Server) 是Unix-like系统中的一个虚拟服务器,是国内贡献给开源组织的一个最优秀的项目之一

    lvs DR模式总结详细笔记文档

    LVS(Linux Virtual Server)是一种基于 Linux 的负载均衡解决方案,能够将incoming请求分布到多个后端服务器上,以提高系统的可扩展性和高可用性。在 DR 模式下,LVS 可以与 Keepalived 一起使用,实现高可用性的...

    salt-lvs:基于SaltStack进行LVS(Linux Virtual Server)的配置管理

    salt-lvs 基于SaltStack进行LVS(Linux Virtual Server)的配置管理 salt/ --> file_roots pillar/ --> pillar_roots

    LVS负载均衡

    LVS,全称Linux Virtual Server,是Linux系统中的一种高性能的负载均衡技术,由章文嵩博士发起并维护,旨在提供一个高质量的虚拟服务器集群解决方案。LVS作为开源项目,其官方网站为www.linuxvirtualserver.org。自...

    LVS+windows server负载

    Linux Virtual Server (LVS) 是一个开源的虚拟服务器集群系统,由章文嵩博士在1998年创立,旨在提供高性能、高可用的网络服务。LVS 提供了三种IP负载均衡技术,包括VS/NAT、VS/TUN和VS/DR,以及八种调度算法,用于...

    linux运维学习笔记:lvs+keepalived集群部分Shell企业案例.pdf

    Linux运维学习笔记中关于LVS+Keepalived集群部分的Shell企业案例涉及了高可用负载均衡技术的搭建和管理。这里将详细探讨这些案例中涉及的知识点。 ### LVS和Keepalived概述 LVS(Linux Virtual Server)是一个负载...

    LINUX+LVS,LVS原理

    LVS(Linux Virtual Server)是一种开源的负载均衡技术,主要用于处理大规模的网络请求,通过构建一个虚拟服务器集群,将任务分发到多个后端的真实服务器上,从而提高系统的可用性和响应速度。LVS的核心组件包括调度...

    linux系统中LVS的实现剖析

    Linux Virtual Server(LVS)是一种用于构建高可用性服务器集群的负载均衡解决方案。LVS能够在Linux内核2.4及以后的版本中实现网络请求的负载均衡,其主要架构基于netfilter框架。netfilter是一个用于在网络栈中进行...

    linux lvs 的DR 模式

    Linux Virtual Server (LVS) 是一个基于 Linux 内核的高性能负载均衡解决方案,它能够通过调度算法将客户端请求分发到多个后端服务器(Real Server),从而实现负载均衡的目的。LVS 支持多种工作模式,其中 Direct ...

    LVS笔记.docx

    **LVS**(Linux Virtual Server)是一种基于Linux内核的虚拟服务器集群系统,它能够实现高效的负载均衡和服务高可用性。对于需要处理大量并发连接和高流量的场景,LVS提供了强大的支持。 ##### 1.1 为什么选择LVS? ...

    用LVS在Linux上搭建负载均衡集群服务

    LVS(Linux Virtual Server)是基于IP层的负载均衡技术,它允许我们构建一个高性能、高可用的服务器集群,以应对大规模网络服务的需求。 1. **设计目标**: - **服务转发**:LVS能够接收来自外部网络的各种基于TCP...

    基于LVS技术的Linux服务器负载均衡研究.pdf

    LVS(Linux Virtual Server)是Linux操作系统下的一种负载均衡技术,它能够将服务请求按照预设的算法分布到集群中的各个服务器上,从而实现服务器资源的有效利用和压力分散。LVS支持三种运行模式: 1. **Virtual ...

    浅谈Linux服务器集群系统LVS.pdf

    Linux服务器集群系统LVS(Linux Virtual Server)是基于IP层和基于内容请求分发的负载平衡调度解决方法,旨在提供高性能、高可用网络服务。LVS服务器集群系统可以实现可伸缩、高可用网络服务,通过检测节点或服务...

    用Linux下的LVS软件实现Linux集群.rar

    Linux下的LVS(Load Virtual Server,负载均衡服务器)是一种高效且强大的网络负载均衡技术,它允许我们将多个服务器组成一个集群,以提供高可用性、可扩展性和性能优化的服务。LVS在操作系统层面工作,通过调度策略...

Global site tag (gtag.js) - Google Analytics