lvs–各类型的原理及实现—(原理篇)

前言:

   LVS即是linux虚拟服务器,是一个虚拟的服务器集群系统,目的是使用集群技术和linux操作系统实现一个高性能、高可用的服务器。采用IP负载均衡技术和基于内容请求分发技术,将请求负载均衡地转移到不同的服务器上执行,从而将一组服务器构成一个高性能、高可用的虚拟服务器。此篇的内容只包含两种较为常用的LVS技术,分别是LVS-NAT和LVS-DR。

一、Linux Cluster类型:

   Linux集群的三种类型分别是负载均衡集群,高可用集群和高性能集群,以下分别对这三种集群进行讲解;

   

   LB:Load Balancing,负载均衡集群;该集群用于实现将同一种应用的大量请求分散到多台主机;

   HA:High Availablity,高可用;当某一主机出现故障时,从服务器能够取而代之,为服务提供冗余性;

   HP:High Performance,高性能;组合多台计算机,可以将一个很复杂、计算量很大的问题分散到多台主机,通过多台主机联合计算,减少计算的时间;

二、负载均衡集群的调度方式:

    LB集群的简图:

    blob.png

   lvs是基于传输层(目标IP和目标端口)分发请求报文,下图是IPVS的工作原理,IPVS是工作于内核空间的netfiliter的INPUT钩子之上的框架;

   下图是DNAT的转发机制图:

 blob.png

三、LVS集群的类型详解:

  (一)LVS-NAT

     lvs-nat是一个多目标的DNAT,通过将请求报文中的目标地址和目标端口修改为某挑出的RS的RIP和POST实现转发:

     客户端的请求报文发送到DIRECTOR的vip接口,此时源IP是CIP,目标IP是VIP,由于IPVS是工作于INPUT链的,当发现请求报文是请求某一集群服务需要向后转发时,IPVS强行改变发送流程,通过FORWARDING链将报文发送至POSTROUTING链,经由算法算出报文发往到那一台后端服务器,报文进入到后端服务器时,此时源IP地址是CIP,目标IP地址是RIP,后端服务器返回报文时,必须将将网关指向DIRECTOR的DIP,返回报文的源地址是RIP,目标地址是CIP,经过DIRECTOR后,源IP是VIP,目标IP是CIP,这个过程就是LVS-NAT的工作原理。

blob.png

LVS-NAT的特性:   

      多目标IP的DNAT,通过将请求报文中的目标地址和目标端口修改为某跳出的RS的RIP的DPORT实现转发

           (1)RIP和DIP必须在同一个IP网络,且应该使用私网地址;RS的网关指向DIP;

           (2)请求报文和响应报文必须经由Director转发;Director易于成为系统瓶颈;

           (3)支持端口映射,可修改请求报文的目标PORT;

           (4)VS必须是linux系统,RS可以是任意系统;

(二)LVS-DR

      LVS-DR是直接路由的方式,通过将请求报文重新封装一个MAC首部进行转发,源MAC是DIP所在的接口的MAC,目标MAC是某挑选出的RS的RIP所在接口的MAC地址;源IP/PORT,以及目标IP/PORT均保持不变

     下图是LVS-DR的工作原理图:

blob.png

     客户端的请求报文通过路由器、交换机将请求报文发送到DIRECTOR上,DIRECTOR通过算法将请求报文发往某一台REAL SERVER上,REAL SERVER的回应报文不再经由DIRECTOR,而是将报文直接返回到CLient上,此时回应报文的源地址为VIP,目标地址是CIP。DIRECTOR、两台REAL SERVER的IP地址都需要配置VIP地址,由于三台主机使用同一个VIP地址会发生地址冲突,所以需要将VIP地址做隐藏,DIRECTOR的VIP地址需要配置在DIRECTOR的网卡别名上,由于地址不属于网卡而是属于内核,所以无论将VIP配置在REAL SERVER的哪个网卡上,内核都会知道IP地址,从而将IP地址通告给路由器。首先需要将REAL SERVER的VIP地址配置在LO网卡的别名上,为之后隐藏VIP地址做准备。同时需要调整内核参数arp_announce和arp_ignore,从而达到隐藏VIP地址的目的。客户端此时只能将请求报文直接发往DIRECTOR,DIRECTOR对请求报文重新封装MAC,通过MAC将报文发往其中一台REAL SERVER,REAL SERVER的回应报文不经由DIRECTOR,而是直接发送到客户端。

  LVS-DR的特性:

    

  Director和各RS都得配置使用VIP;

             (1)确保前端路由器将目标IP为VIP的请求报文发往DIrector:

                    (a)在前端网关做静态绑定;

                    (b)在RS上使用arptables;

                    (c)在RS上修改内核参数以限制ARP通告及应答级别;

                           arp_announce

                           arp_ignore

             (2)RS的RIP可以使用私网地址,也可以是公网地址;RIP与DIP在同一网络;RIP的网关不能指向DIP,以确保响应报文不会经由Director;

             (3)RS跟Director要在同一个物理网络;

             (4)请求报文要经由Director,但响应不能经由Director,而是由RS直接发往Client;

             (5)不支持端口映射;

    

四、IPVS的调度算法

     根据其调度时是否考虑各RS当前的负载状态,可分为静态方法和动态方法两种,静态方法是仅根据算法本身进行调度,动态方法主要根据每RS当前的负载状态及调度算法进行调度。

     静态方法:

          (1)RR:roundrobin,轮询;               

          (2)WRR:weighted RR,加权轮询;

          (3)SH:source hashing,源IP地址哈希,用于实现session sticy;

          (4)DH:destination hashing,目标IP地址哈希,将发往同一个目标地址的请求始终转发至第一次挑中的RS;

      动态方法:

          (1)LC:least connections:最少连接

          (2)WLC:weight LC 加权最少连接

          (3)SED:shortest expection delay

          (4)NQ:never queue

          (5)LBLC:locality-based LC,动态DH算法

          (6)LBLCR:LBLC with replication,带复制功能的LBLC;

   

 

原创文章,作者:因为有你,如若转载,请注明出处:http://www.178linux.com/54645

(0)
因为有你因为有你
上一篇 2016-10-27
下一篇 2016-10-27

相关推荐

  • apache httpd 站点搭建

    apache  httpd 站点搭建 apache  httpd 站点搭建 1 §·httpd程序包使用yum安装 1 ※·[root@www ~]# yum  install  httpd.x86_64 1 ※·关于生成的配置文件简单介绍: 2 §·http主配置文件介绍 3 ※·主配置文件分为三大部分: 3 §·h…

    Linux干货 2016-12-05
  • bash脚本之数组及字符串切片,登陆配置文件

    一,概述 数组(就是一堆变量的集合) 变量:存储单个元素的内存空间 数组:存储多个元素的连续的内存空间,相当于多个变量的集合/ 数组名和索引     索引:编号从0开始,属于数值索引     注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引,bash4.0版本之后…

    Linux干货 2016-09-01
  • shell脚本执行

    shell脚本执行 对于我们这些小白而讲,shell脚本无疑是最令人头疼的事了,我再这里讲一下shell脚本运行要注意的哪些。 shell脚本就好像c++,java代码一样,按照从上到下然后从左到右的顺序执行。就像我们日常读书一样。如果shell命令遇见了子进程(嵌套代码),程序就会跟着顺序进入子进程。当子进程完成后,回到父进程,并且把父进程所需要的参数提交…

    2017-06-05
  • LVM逻辑卷扩展与缩小

    逻辑卷扩容:扩展逻辑卷前一定要卸载设备和挂载点的关联 第一步:把逻辑卷lv扩展至300M 第二步:检查硬盘,并重置硬盘容量 第三步:重新挂载,查看挂载状态   缩小逻辑卷:对逻辑卷缩容时,丢失数据的风险更大。在执行操作前一定要提前备份好数据。在进行缩减前先把文件系统卸载掉。 第一步:检查文件 第二步:把逻辑卷lv减小到100M 第三步:重新挂载并查…

    2017-12-17
  • vsftp通过pam_mysql做虚拟用户认证

    vsftpd可以通过三种账户登录系统: 系统账户:系统本地账户登录系统,默认进入的目录是用户家目录,可以在所有有权限的路径切换; 匿名账户:匿名用户登录,然后映射为一个本地用户; 虚拟账户:既不是系统本地用户也不是匿名用户,而是通过pam做第三方认证的方法,支持文件和数据库,ldap的认证,此处通过mysql进行实验; 一、准备实验环境 实验在一台虚拟机上进…

    Linux干货 2017-06-07
  • Tomcat详解

    Tomcat详解 1、tomcat安装 tomcat的组件:<Server> <Service> <connector/> <connector/> <Engine> <Host /> <Host> <Context/> … </Host> &lt…

    2017-04-27

评论列表(1条)

  • 马哥教育
    马哥教育 2016-10-30 20:49

    文章内容上比较完整地,但是整体排版是不是太乱了点?建议多看看别人写的博客,来提升自己的写作能力哦。