linux下的lvs三种模式及配置

   lvs:linux virtual server,linux虚拟服务器。是linux平台下的负载均衡软件。

  优点:a、开源,免费b、在网上能找到相关技术资源c、具有软件负载均衡的优点。

  技术简介:

  lvs集群采用IP负载均衡技术和基于内容请求分发技术。调度器具有很好的吞吐率,将请求均衡的转移到不同的服务器上执行,调度器自动屏蔽服务器的故障,从而将一组服务器构成一个高性能的高可用的虚拟服务器。整个服务器集群的结构对客户是透明的,无需修改客户端和服务器端的程序。

  集群的三层架构:

  A、负载调度器,是整个集群对外面的前端机,负责将客户的请求发送到一组服务器上执行,而客户认为服务是来自一个IP地址

  B、服务器池,是一组真正执行客户请求的服务器,执行的服务有web、mail、ftp和dhs等

  C、共享存储,为服务器提供一个共享的存储区,很容易使得服务器池拥有相同的内容,提供相同的服务。

  调度器:

  调度器是服务器集群系统的唯一入口点,可以采用IP负载均衡技术、基于内容请求分发技术或者两者的结合。

  调度器采用ip负载均衡技术,基于内容请求分发技术或者两者的结合。在IP负载均衡技术中,需要服务器池拥有相同的内容提供相同的服务。当客户请求到达时,调度器根据服务器负载情况和设定的调度算法从服务器池中选择一个服务器,将带请求转发到选出的服务器,并记录这个调度;当这个请求的其他报文到达,也会被转发到前面选出的服务器。

  在基于内容请求分发技术中,服务器可以提供不同的服务,当客户请求到达时,调度器可以根据请求的内容选择服务器执行请求。

  调度算法:

  轮叫调度:以轮叫的方式依次将请求调度不同的服务器,算法简洁,无需记录当前所有链接的状态,是无状态的调度

  加权轮叫调度:用相应的权值表示服务器的处理性能,默认权值为1.按权值的高低和轮叫方式分配请求到各服务器

  最小连接调度:把新的链接请求分配到当前连接数最小的服务器,是一种动态的调度算法,通过服务器当前活跃的连接数来估算服务器的负载情况。

  加权最小连接调度:各个服务器相应的权值表示其处理性能。尽可能使服务器已经建立的连接数和其权值成比例

  基于局部性的最小链接:在服务器的负载平衡情况下,将相同目标IP地址的请求调度到同一台服务器,提高各服务器的访问局部性和主存cache命中率。

  带复制的基于局部性的最少链接:与基于局部性的最小链接不同的是,这个需要维护从一个目标IP到一组服务器的映射。

  目标地址散列调度:静态映射算法,通过一个散列函数将一个目标IP地址映射到一台服务器

  源地址散列调度:与目标地址散列调度相反,根据请求的源IP地址作为散列值,从静态分配的散列表找出相应的服务器。

  负载均衡技术 vs/nat:通过网络地址转换技术,将一组服务器构成一个高可用的,高性能的虚拟服务器。 vs/tun:通过ip隧道实现虚拟服务器 vs/dr:通过直接路由实现虚拟服务器虚拟ip:director用于向客户端计算机提供服务的ip地址真实ip:在集群节点上使用ip地址,提供真实服务的机器 director的ip:director用于连接到D/rip网络的ip地址客户端ip:分配给客户端计算机的ip地址,用作发送给集群的请求的源地址

  1、lvs(nat模式配置)

  (1)准备好网络环境

  真实服务器(应用服务,ip地址,网关)

  调度服务器(ip地址,数据转发设置)

  防火墙服务器(ip地址,数据转发设置,NAT配置)

  (2)调度服务器配置

  # vim /etc/sysctl.conf

  net.ipv4.ip_forward = 1

  # sysctl -p

  # yum install ipvsadm

  # ipvsadm -A -t 172.16.10.111:80 -s rr

  # ipvsadm -a -t 172.16.10.111:80 -r 10.0.0.11:80 -m

  # ipvsadm -a -t 172.16.10.111:80 -r 10.0.0.12:80 -m

  # ipvsadm -a -t 172.16.10.111:80 -r 10.0.0.13:80 -m

  # service ipvsadm save

  (3)防火墙的配置

  # vim /etc/sysctl.conf

  net.ipv4.ip_forward = 1

  # sysctl -p

  # iptables -t nat -A PREROUTING -i eth1 -s 10.10.10.0/24 -p tcp --dport 80 -j DNAT --to-destination=172.16.10.111:80

  2、lvs(dr模式配置)

  (1)客户端(Client)配置

  eth0(cip):10.10.10.10

  gw:10.10.10.110

  (2)防火墙配置(Fireware)配置

  ip配置

  eth0:172.16.10.111 (防火墙和调度服务器通信地址)

  eth1:10.10.10.11 (客户端网关)

  eth2:10.0.0.163 (防火墙和真实机的通信地址)

  # vim /etc/sysctl.conf

  net.ipv4.ip_forward = 1

  # sysctl -p

  # iptables -t nat -A PREROUTING -i eth1 -s 10.10.10.0/24 -p tcp --dport 80 -j DNAT --to-destination=172.16.10.111:80

  (3)调度服务器(ldirector)配置

  ip配置

  eth0:10.0.0.164 (和真实服务器通信地址)

  eth1:172.16.10.100 (虚拟ip(vip))

  gw:172.16.10.111

  注意:解决Error, some other host already uses address 10.0.0.164.问题

  # vim /etc/sysconfig/network-scripts/ifup-eth 注释掉一下四行

  # if ! /sbin/arping -q -c 2 -w 3 -D -I ${REALDEVICE} ${ipaddr[$idx]} ; then

  # net_log $"Error, some other host already uses address ${ipaddr[$idx]}."

  # exit 1

  # fi

  配置数据包转发

  # vim /etc/sysctl.conf

  net.ipv4.ip_forward = 1

  # sysctl -p

  配置调度

  # ipvsadm -A -t 172.16.10.100:80 -s rr

  # ipvsadm -a -t 172.16.10.100:80 -r 10.0.0.11:80 -g

  # ipvsadm -a -t 172.16.10.100:80 -r 10.0.0.12:80 -g

  # ipvsadm -a -t 172.16.10.100:80 -r 10.0.0.13:80 -g

  # ipvsadm -L -n 查看ipvsadm配置

  # ipvsadm -L -n --stats 查看ipvsadm状态

  添加网关

  # route add default gw 172.16.10.111

  (4)真实服务器(real server)配置

  ip配置

  1)ip:10.0.0.11/16

  gw:10.0.0.139

  vip:172.16.10.100

  # ifconfig lo:0 172.16.10.100/32 broadcast 172.16.10.100

  禁用接收广播回应配置

  #vim /etc/sysctl.conf

  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

  或者

  # yum install arptables_jf

  # arptables -A IN -d 172.16.10.100 -j DROP

  添加路由

  # route add -host 172.16.10.100 dev lo:0

时间: 2024-08-01 18:31:34

linux下的lvs三种模式及配置的相关文章

LVS三种模式与八种调度算法

三种LVS负载均衡模式 1.NAT模式网络地址转换,工作在网络层(三层),只有VIP是公网IP,其余都是私网IP,Real Server指定LVS为网关,LVS开启路由转发,源和目标地址转换,数据的进出期间,无论是进来的流量,还是出去的流量,都必须经过DR,会产生一种瓶颈,适合小网络,规模10台左右. 工作原理: 1>.用户发送请求报文到LVS的VIP上,VIP选择一个Real Server,并记录连接信息到hash表中,然后修改用户的请求报文的目的IP地址为Real Server的地址,将请求

Linux 下系统调用的三种方法

系统调用(System Call)是操作系统为在用户态运行的进程与硬件设备(如CPU.磁盘.打印机等)进行交互提供的一组接口.当用户进程需要发生系统调用时,CPU 通过软中断切换到内核态开始执行内核系统调用函数.下面介绍Linux 下三种发生系统调用的方法: 通过 glibc 提供的库函数 glibc 是 Linux 下使用的开源的标准 C 库,它是 GNU 发布的 libc 库,即运行时库.glibc 为程序员提供丰富的 API(Application Programming Interfac

VMware虚拟机修改Linux MAC地址的三种方法

  MAC地址为网卡的物理地址,在Windows系统下非常容易修改,在linux模式下则有些复杂, 我们看看VMware虚拟机中修改Linux MAC地址的方法 方法一: 这个方法最直接简单有效,修改Linux系统里相关rc.local文件MAC值即可. 方法二: 修改虚拟机的*.vmx文件,这种方法最值得推荐,因为这样就类似于重新"烧录"了VMware虚拟机的"物理网卡ROM".方法是: 分两种情况: 第一种: ethernet0.addressType=&quo

三种模式建设宽带接入网

今年上半年,我国数据通信相关业务增长迅速,并达到了相当的收入规模.正是基于该领域的快速发展,电信运营商近年来积极建设宽带网络,目前,宽带接入网络成为建设的重要内容之一.但在复杂的电信网络环境下,如何因地制宜地建设宽带接入网呢?带着这一问题,记者日前走访了港湾网络.港湾网络的专家指出,目前三种模式适合中国宽带接入网络的建设.模式之一:互补的端局组网模式 港湾的专家指出,由于中国电信.中国网通等电信运营商拥有大量的铜线资源,因此DSL宽带接入技术成为当今建设的重点.而PSTN网络的端局交换模式,使基

小米、华为与联想,背后隐含的三种模式(转)

  1 月 15 号参加了小米产品发布会,正当雷军在台上讲小米 Note 的种种功能时我却突然意识到小米.华为.联想的拼杀到了 2015 年已经完全进入到了一个新的阶段.在功能和体验上诚然大家会激烈的彼此追赶但其实已经拉不开太多的距离,最终决定胜负的很可能是手机背后所体现出来的模式.这很像一场国战,胜负不再取决于一城一地而是取决于综合国力. 小米.华为与联想背后隐含的商业模式 虽然最终呈现给用户的手机是类似的,但就我看来这三家背后隐含的模式却是有本质不同. 联想是经典的经营管理派.这一派的基本逻

分析在Worklight中开发本地功能的三种模式

文章将分析在 Worklight 中开发本地功能的三种模式:调用 Cordova 支持的本地功能:通过 Worklight common API 调用开发的本地功能:编写 Cordova 的插件,调用本地功能.然后通过相应的实例展现不同方法的使用模式,向读者展现 Worklight 在和本地功能结合上的能力.最后分析各自的优缺点和使用的环境. 纯 web 模式的局限性 在 Worklight 架构下,纯 web 模式虽然可以像本地应用一样被安装在手机上,但是所提供的服务和传统的网页相比,几乎没有

IIS下PHP的三种配置方式对比_php技巧

在Windows IIS 6.0下配置PHP,通常有CGI.ISAPI和FastCGI三种配置方式,这三种模式都可以在IIS 6.0下成功运行,下面我就讲一下这三种方式配置的区别和性能上的差异.   1.CGI(通用网关接口/Common Gateway Interface)一般是可执行程序,例如EXE文件,和WEB服务器各自占据着不同的进程,而且一般一个CGI程序只能处理一个用户请求.这样,当用户请求数量非常多时,会大量占用系统的资源,如内存.CPU时间等,造成效能低下.   2.ISAPI(

脚本安需导入(装载)的三种模式的对比_javascript技巧

何谓安需装载?     脚本程序一般都是下载后执行,当脚本库非常庞大时,一次性下载起来非常费时,传统的解决方式是,按功能模块把脚本写在不同的文件中,页面上手动加入 script标签装载指定内容,但是这有一些缺点,类库的使用者需要知道没个脚本之间的关系,顺序要求等等,而不可能要求每个类库使用者都对其非常熟悉,出错的可能性很大.于是很多框架开始支持导入指令,想使用什么一个导入函数就完了,不必一堆堆的script文件,不用小心翼翼的关注着他们的依赖关系. 安需装载的困境:       早期安需装载(即

VMWare 网络连接的三种模式(bridged、NAT、host-only)

简述 VMWare 提供了三种网络连接模式:bridged(桥接模式).NAT(网络地址转换模式).host-only(仅主机模式).要想在网络管理和维护中合理应用它们,就应该先了解一下这三种模式. 简述 bridged桥接模式 NAT网络地址转换模式 host-only仅主机模式 bridged(桥接模式) 在 bridged 模式下,VMWare 虚拟出来的操作系统就像是局域网中的一台独立的主机(主机和虚拟机处于对等地位),它可以访问网内任何一台机器.在 bridged 模式下,我们往往需要