使用LVS+NAT搭建集群实现负载均衡

使用LVS+NAT搭建集群实现负载均衡

LVS集群简介

   计算机集群简称集群是一种计算机系统,它通过一组松散集成的计算机软件或硬件连接起来高度紧密地协作完成计算工作。在某种意义上,他们可以被看作是一台计算机。集群系统中的单个计算机通常称为节点,通常通过局域网连接,但也有其它的可能连接方式。集群计算机通常用来改进单个计算机的计算速度和/或可靠性。一般情况下集群计算机比单个计算机,比如工作站或超级计算机性能价格比要高得多   

 

 

LVS集群分布图

 

集群有三种类型:

                1:负载均衡

                2:高可用集群式我们互联网行业常用的集群架构

                3:高性能计算集群--HPC
 (1)负载均衡集群--LB
    负载均衡集群为企业提供了更为实用,性价比更高的系统架构解决方案。负载均衡集群把很多客户集中访问的请求负载压力可能尽可能平均的分摊到计算机集群中处理。客户请求负载通常包括应用程度处理负载和网络流量负载。这样的系统非常适合向使用同一组应用程序为大量用户提供服务。每个节点都可以承担一定的访问请求负载压力,并且可以实现访问请求在各节点之间动态分配,以实现负载均衡。      
   负载均衡运行时,一般通过一个或多个前端负载均衡器将客户访问请求分发到后端一组服务器上,从而达到整个系统的高性能和高可用性。这样计算机集群有时也被称为服务器群。一般高可用性集群和负载均衡集群会使用类似的技术,或同时具有高可用性与负载均衡的特点。
                                

 负载均衡集群的作用
1)分担访问流量(负载均衡)
2)保持业务的连续性(高可用

 

(2)高可用性集群--HA
    一般是指当集群中的任意一个节点失效的情况下,节点上的所有任务自动转移到其他正常的节点上,并且此过程不影响整个集群的运行,不影响业务的提供。 类似是集群中运行着两个或两个以上的一样的节点,当某个主节点出现故障的时候,那么其他作为从 节点的节点就会接替主节点上面的任务。从节点可以接管主节点的资源(IP地址,架构身份等),此时用户不会发现提供服务的对象从主节点转移到从节点。                                                
   高可用性集群的作用:当一个机器宕机另一台进行接管。比较常用的高可用集群开源软件有:       keepalive,heardbeat。  
                                                                  

 (3)高性能计算集群--HPC
    高性能计算集群采用将计算任务分配到集群的不同计算节点儿提高计算能力,因而主要应用在科学计算领域。比较流行的HPC采用Linux操作系统和其它一些免费软件来完成并行运算。这一集群配置通常被称为Beowulf集群。这类集群通常运行特定的程序以发挥HPCcluster的并行能力。这类程序一般应用特定的运行库, 比如专为科学计算设计的MPI库。
    HPC集群特别适合于在计算中各计算节点之间发生大量数据通讯的计算作业,比如一个节点的中间结果或影响到其它节点计算结果的情况。


常用集群软硬件

常用开源集群软件有:lvs,keepalived,haproxy,nginx,apache,heartbeat

常用商业集群硬件有:F5,  Netscaler, Radware,A10等

 

LVS集群的优点

1)把单台计算机无法承受的大规模的并发访问或数据流量分担到多台节点设备上分别处理,减少用户等待响应的时间,提升用户体验。
2)单个重负载的运算分担到多台节点设备上做并行处理,每个节点设备处理结束后,将结果汇总,返回给用户,系统处理能力得到大幅度提高。
3)7*24小时的服务保证,任意一个或多个设备节点设备宕机,不能影响到业务。在负载均衡集群中,所有计算机节点都应该提供相同的服务,集群负载均衡获取所有对该服务的如站请求。

 

LVS的三种工作模式:
1)VS/NAT模式(Network address translation)
2)VS/TUN模式(tunneling)
3)DR模式(Direct routing)

NAT模式的概述与工作原理

NAT模式概述

    Network Address Translation(NAT地址转化)

    NAT(网络地址映射)通过网络地址转换。 NAT方式可支持任何的操作系统,以及私有网络,并且只需一个Internet IP地址,但是整个系统的性能受到限制。因为执行NAT每次需要重写包,有一定的延迟;另外,大部分应用有80%的数据是从服务器流向客户机,也就是用户的请求非常短,而服务器的回应非常大,对负载均衡器形成很大压力,成为了新

 

LVS NAT 模式工作原理: NAT模式-网络地址转换
    这个是通过网络地址转换的方法来实现调度的。首先调度器(LB)接收到客户的请求数据包时(请求的目的IP为VIP),根据调度算法决定将请求发送给哪个后端的真实服务器(RS)。然后调度就把客户端发送的请求数据包的目标IP地址及端口改成后端真实服务器的IP地址(RIP),这样真实服务器(RS)就能够接收到客户的请求数据包了。真实服务器响应完请求后,查看默认路由(NAT模式下我们需要把RS的默认路由设置为LB服务器。)把响应后的数据包发送给LB,LB再接收到响应包后,把包的源地址改成虚拟地址(VIP)然后发送回给客户端。

 

步骤1:客户端访问VIP1的网站

步骤2:客户端访问调度器时,调度器通过网络地址转换,调度器重写请求报文的目标地址,根据预设的调度算法,将请求分派给后端的真实服务器;

 

步骤3:真实服务器的响应报文通过调度器时,报文的源地址被重写,再返回给客户,完成整个负载调度过程。

原理图简述:
1)客户端请求数据,目标IP为VIP
 2)请求数据到达LB服务器,LB根据调度算法将目的地址修改为RIP地址及对应端口(此RIP地址是根据调度算法得出的。)并在连接HASH表中记录下这个连接。
3)数据包从LB服务器到达RS服务器webserver,然后webserver进行响应。Webserver的网关必须是LB,然后将数据返回给LB服务器。
4)收到RS的返回后的数据,根据连接HASH表修改源地址VIP&目标地址CIP,及对应端口80.然后数据就从LB出发到达客户端。
5)客户端收到的就只能看到VIP\DIP信息。

NAT模式优缺点:
1、NAT技术将请求的报文和响应的报文都需要通过LB进行地址改写,因此网站访问量比较大的时候LB负载均衡调度器有比较大的瓶颈,一般要求最多之能10-20台节点
2、只需要在LB上配置一个公网IP地址就可以了。
3、每台内部的节点服务器的网关地址必须是调度器LB的内网地址。
4、NAT模式支持对IP地址和端口进行转换。即用户请求的端口和真实服务器的端口可以不一致。

 

 

一:实验目标

1:正确理解NAT的工作原理  

2:使用LVS+NAT搭建集群实现负载均衡

 

二:实验拓扑

 

                                         真实环境中的拓扑图                                       

                                      本次实验拓扑

 


各类IP的作用


CIP


   客户端计算机的IP可能是一个本地的、VIP在同一网络的私有ip地址,者是一个因特网上的公共ip地址。用作向集群发送请求的源ip地址


VIP


   分发器上虚拟IP是由分发器的接口分出的一个虚拟IP,用于接收访问集群服务的请求


DIP


   分发器上的DIP,用于将分发器上VIP接收访问集群服务的请数据包进行解析,再转发各个集群节点


RIP


   集群服务器上的真实IP是客户端访问集群的终点。在LVS术语中,向外部世界提供服务的节点叫做真实服务器,因此在真实服务器上使用的ip地址叫做真实ip地址

 

三:实验环境

1、准备3台

分发器:xuegod63  VIP:eth1:192.168.1.63

                DIP:eth0192.168.2.63

RIP:xuegod62:  eth0: vmnet4 : 192.168.2.62 网关: 192.168.2.63

RIP:xuegod64:  eth0: vmnet4 : 192.168.2.64 网关: 192.168.2.63           

2、iptables -F , 清除规则

3、selinux关闭

4:red had 6.5版本 64位操作系统

 

四:实验代码

xuegod63配置成分发器:

1、打开路由转发功能

[[email protected] ~]# vim /etc/sysctl.conf

改:net.ipv4.ip_forward = 0

为:net.ipv4.ip_forward = 1

[[email protected] ~]# sysctl -p #让配置生效:

 

2、配置网络环境: 添加一个网卡, 配置成以下网络环境

eth0 192.168.1.63 模式:br0 模拟公网

eth1 192.168.2.63 模式:vmnet4 模拟公网

Director分发器:需要开启80(服务的)端口

 

3:安装: LVS管理工具: ipvsadmin

[[email protected] Packages]# rpm -ivh ipvsadm-1.25-9.el6.x86_64.rpm

 

4、使用这个命令设置规则:

[[email protected] ~]# ipvsadm -A -t 192.168.1.63:80 -s rr #rr代表轮循


ipvsadm 命令参数


ipvsadm 命令的作用


-A


添加


-t


指定分发器上的VIP地址


-s


指定调度算法 rr表示round-robin 轮循


-a


表示添加real server的地址


-r


指定real server的IP地址


-m


表示masquerade 也就是NAT方式的LVS

[[email protected] ~]# ipvsadm -a -t 192.168.1.63:80 -r 192.168.2.64 -m

[[email protected] ~]# ipvsadm -a -t 192.168.1.63:80 -r 192.168.2.62 -m

 

查看: ipvsadm 配置及查看内核IPVS表和算法的工具类似于iptables

[[email protected] ~]# ipvsadm -L -n

IP Virtual Server version 1.2.1 (size=4096)

Prot LocalAddress:Port Scheduler Flags

-> RemoteAddress:Port Forward Weight ActiveConn InActConn

TCP 192.168.1.63:80 rr

-> 192.168.2.62:80 Masq 1 0 0

-> 192.168.2.64:80 Masq 1 0 0

保存ipvsadm的配置

[[email protected] ~]# /etc/init.d/ipvsadm save #保存以上的配置

 

RealServer:xuegod62和xuegod64上面配置:

准备: 配置IP:REAL SERVER自己的网络相关信息配置成如下:。

xuegod62: eth0: vmnet4 : 192.168.2.62 网关: 192.168.2.63

xuegod64: eth0: vmnet4 : 192.168.2.64 网关: 192.168.2.63

 

1:配置xuegod64为realserver, 并启web服务

[[email protected] ~]# yum install -y httpd

[[email protected] ~]# vim /etc/httpd/conf/httpd.conf

ServerName 192.168.2.64:80 #改为这样

[[email protected] ~]# service httpd restart

[[email protected] ~]# echo "192.168.2.64" > /var/www/html/index.html #(实验期间,各个服务器的页面同)

 

2:配置xuegod62为realserver, 并启web服务

[[email protected] ~]# yum install -y httpd

[[email protected]2 ~]# vim /etc/httpd/conf/httpd.conf

ServerName 192.168.2.62:80 #改为这样

[[email protected] ~]# service httpd restart

[[email protected] ~]# echo "192.168.2.62" > /var/www/html/index.html #(实验期间,各个服务器的页面同)

 

测试:

在xuegod63上测试realserver : 

[[email protected] ~]# yum install elinks  

[[email protected] ~]# elinks 192.168.2.64 --dump

192.168.2.64

[[email protected] ~]# elinks 192.168.2.62 --dump

192.168.2.62

在xuegod63上测试VIP:

 

在物理机上测试

访问: 在物理上打开浏览器访问: 每按F5刷新一次,就会变换一个页面。

#每刷新一次就跳转到下一个页面,这样就实现了地址转换和负载均衡。

时间: 2024-12-25 18:22:22

使用LVS+NAT搭建集群实现负载均衡的相关文章

使用LVS+DR搭建集群实现负载均衡

使用LVS+DR搭建集群实现负载均衡 DR模式的概述与工作原理 DR模式服务概述:        Direct Routing(直接路由) --在同一个地域,同一个网段 Director分配请求到不同的real server.real server处理请求后直接回应给用户,这样director负载均衡器仅处理客户机与服务器的一半连接.负载均衡器仅处理一半的连接,避免了新的性能瓶颈,同样增加了系统的可伸缩性.Direct Routing由与采用物理层(修改MAC地址)技术,因此所有服务器都必须在一

架构之路:nginx与IIS服务器搭建集群实现负载均衡(三)

参考网址:https://blog.csdn.net/zhanghan18333611647/article/details/50811980 [前言] 在<架构之路:nginx与IIS服务器搭建集群实现负载均衡(二)>中提到有好多有趣的地方,接下来就为大家一块儿讲讲在深入研究过程中遇到那些有趣的事情. ·实战之行--发现问题 ·探索之旅--寻出问题原因 ·解决之道--解决问题 [实战之行] 在<架构之路:nginx与IIS服务器搭建集群实现负载均衡(二)>中做了小Demo,当时做

架构之路:nginx与IIS服务器搭建集群实现负载均衡(二)

[前言] 在<架构之路:nginx与IIS服务器搭建集群实现负载均衡(一)>中小编简单的讲解了Nginx的原理!俗话说:光说不练假把式.接下来,小编就和大家一起来做个小Demo来体会一下Nginx的神奇之处. [准备工作] ·安装一款文本编辑器(这里以Notepad++为例) ·下载Nginx(这里以Nginx-1.4.7为例,其他版本操作相同) ·建两个简单网页:在文件夹test1新建一个html页内容为--我是Test1,在文件夹test2新建一个html页内容为--我是Test2) ·将

用apache和tomcat搭建集群,实现负载均衡

型的企业应用每天都需要承受巨大的访问量,在着巨大访问量的背后有数台服务器支撑着,如果一台服务器崩溃了,那么其他服务器可以使企业应用继续运行,用户对服务器的运作是透明化的,如何实现这种透明化呢?由如下问题需要解决. 一.Session的复制 二.如何将请求发送到正常的服务器 针对以上问题,可以使用群集和负载均衡来解决,整体架构如下:  中间由一台服务器做负载均衡(Load Balancer),它将所有请求,根据一定的负载均衡规则发送给指定的群集服务器(Cluster),群集服务器拥有着相同的状态和

LVS搭建集群实现负载均衡-NAT模式

服务介绍: LVS 简称 Linux Virtual Server,在实际环境中经常作为B/S结构的网络应用中的负载均衡器来使用,工作在7层网络模型中的,网络层,也就是通常说的IP层,由于数据的处理是在Linux内核态完成的,所以性能很高 nat 模式: 支持任 何操作系统,以及私有网络,只需要一个公网ip ,系统性能受到限制,每次执行nat需要重写包,有一定延迟. 实验环境 实验环境: xuegod 63   VIP:eth0 192.168.0.103    ; DIP:eth1 192.1

LVS+Keepalived搭建MyCAT高可用负载均衡集群

LVS+Keepalived 介绍 LVS LVS是Linux Virtual Server的简写,意即Linux虚拟服务器,是一个虚拟的服务器集群系统.本项目在1998年5月由章文嵩博士成立,是中国国内最早出现的自由软件项目之一.目前有三种IP负载均衡技术(VS/NAT.VS/TUN和VS/DR),十种调度算法(rrr|wrr|lc|wlc|lblc|lblcr|dh|sh|sed|nq). Keepalvied Keepalived在这里主要用作RealServer的健康状态检查以及Mast

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

我们曾经介绍过三种Tomcat集群方式的优缺点分析.本文将介绍Tomcat集群与负载均衡技术具体实施过程. 在进入集群系统架构探讨之前,先定义一些专门术语: 1. 集群(Cluster):是一组独立的计算机系统构成一个松耦合的多处理器系统,它们之间通过网络实现进程间的通信.应用程序可以通过网络共享内存进行消息传送,实现分布式计算机. 2. 负载均衡(Load Balance):先得从集群讲起,集群就是一组连在一起的计算机,从外部看它是一个系统,各节点可以是不同的操作系统或不同硬件构成的计算机.如

Nginx实现集群的负载均衡配置过程详解

Nginx实现集群的负载均衡配置过程详解 Nginx 的负载均衡功能,其实实际上和 nginx 的代理是同一个功能,只是把代理一台机器改为多台机器而已. Nginx 的负载均衡和 lvs 相比,nginx属于更高级的应用层,不牵扯到 ip 和内核的修改,它只是单纯地把用户的请求转发到后面的机器上.这就意味着,后端的 RS 不需要配置公网. 一.实验环境 Nginx 调度器 (public 172.16.254.200 privite 192.168.0.48)RS1只有内网IP (192.168

通过Apache+mod_JK+Tomcat集群实现负载均衡

通过Apache+mod_JK+Tomcat集群实现负载均衡 1.概念 通过Apache+mod_JK+Tomcat集群搭建起来的环境主要用来实现负载均衡和高可用性.使用apache作为反向代理服务器实现负载均衡,使用mod_jk可以实现节点的故障恢复功能,达到高可用性.使用tomcat集群功能实现sessionID共享复制.用户访问数据在到达apache后,如果是静态内容,直接由apache处理,如果是动态请求,就通过mod_jk调用后端的一台tomcat服务器去处理请求,可以通过黏性Sess