码迷,mamicode.com
首页 > 其他好文 > 详细

LVS+Keepalived

时间:2017-10-18 23:05:19      阅读:251      评论:0      收藏:0      [点我收藏+]

标签:sof   configure   web服务   ip协议   debug   ima   dmi   forward   高性能   

1》Keepalived简介       

      Keepalived是Linux下一个轻量级别的高可用解决方案,高可用(High Avalilability,HA),其实两种不同的含义:广义来讲,是指整个系统的高可用行,狭义的来            讲就是之主机的冗余和接管,它与HeartBeat RoseHA 实现相同类似的功能,都可以实现服务或者网络的高可用,但是又有差别,HeartBeat是一个专业的、功能完            善的高可用软件,它提供了HA 软件所需的基本功能,比如:心跳检测、资源接管,检测集群中的服务,在集群节点转移共享IP地址的所有者等等。HeartBeat功能强          大,但是部署和使用相对比较麻烦,与HeartBeat相比,Keepalived主要是通过虚拟路由冗余来实现高可用功能,虽然它没有HeartBeat功能强大,但是Keepalived部          署和使用非常的简单,所有配置只需要一个配置文件即可以完成;      

      Keepalived起初是为LVS设计的,专门用来监控集群系统中各个服务节点的状态,它根据TCP/IP参考模型的第三、第四层、第五层交换机制检测每个服务节            点的状态,如果某个服务器节点出现异常,或者工作出现故障,Keepalived将检测到,并将出现的故障的服务器节点从集群系统中剔除,这些工作全部是自动完成            的,不需要人工干涉,需要人工完成的只是修复出现故障的服务节点,后来Keepalived又加入了VRRP的功能,VRRP(Vritrual Router Redundancy Protocol,虚拟路          由冗余协议)出现的目的是解决静态路由出现的单点故障问题,通过VRRP可以实现网络不间断稳定运行,因此Keepalvied 一方面具有服务器状态检测和故障隔离功            能,另外一方面也有HA cluster功能,下面介绍一下VRRP协议实现的过程;

2》VRRP协议与工作原理          

      在现实的网络环境中,主机之间的通信都是通过配置静态路由或者(默认网关)来完成的,而主机之间的路由器一旦发生故障,通信就会失效,因此这种通信模           式当中,路由器就成了一个单点瓶颈,为了解决这个问题,就引入了VRRP协议,熟悉网络的学员对VRRP协议应该不陌生,它是一种主备模式的协议,通过                 VRRP可以在网络发生故障时透明的进行设备切换而不影响主机之间的数据通信,这其中涉及到两个概念:物理路由器和虚拟路由器;

      VRRP可以将两台或者多台物理路由器设备虚拟成一个虚拟路由,这个虚拟路由器通过虚拟IP(一个或者多个)对外提供服务,而在虚拟路由器内部十多个物           理路由器协同工作,同一时间只有一台物理路由器对外提供服务,这台物理路由设备被成为:主路由器(Master角色),一般情况下Master是由选举算法产生,它           拥有对外服务的虚拟IP,提供各种网络功能,如:ARP请求,ICMP 数据转发等,而且其它的物理路由器不拥有对外的虚拟IP,也不提供对外网络功能,仅仅接收         MASTER的VRRP状态通告信息,这些路由器被统称为“BACKUP的角色”,当主路由器失败时,处于BACKUP角色的备份路由器将重新进行选举,产生一个新的主           路由器进入MASTER角色,继续提供对外服务,整个切换对用户来说是完全透明的;

       每个虚拟路由器都有一个唯一的标识号,称为VRID,一个VRID与一组IP地址构成一个虚拟路由器,在VRRP协议中,所有的报文都是通过IP多播方式发送             的,而在一个虚拟路由器中,只有处于Master角色的路由器会一直发送VRRP数据包,处于BACKUP角色的路由器只会接受Master角色发送过来的报文信息,用来         监控Master运行状态,一一般不会发生BACKUP抢占的情况,除非它的优先级更高,而当MASTER不可用时,BACKUP也就无法收到Master发过来的信息,于是           就认定Master出现故障,接着多台BAKCUP就会进行选举,优先级最高的BACKUP将称为新的MASTER,这种选举角色切换非常之快,因而保证了服务的持续可           用性;

3》Keepalvied的工作原理        

      上面我们介绍了Keepalived通过VRRP实现高可用性的工作原理,而Keepalived作为一个高性能集群软件,它还能实现对集群中服务器运行状态的监控以              及故障隔离,下面我们介绍一下Keepalived对服务器运行状态和故障隔离的工作原理;

         Keepalived工作在TCP/IP 参考模型的 三层、四层、五层,也就是分别为:网络层,传输层和应用层,根据TCP、IP参数模型隔层所能实现的功能,                  Keepalived运行机制如下:

         在网络层: 我们知道运行这4个重要的协议,互联网络IP协议,互联网络可控制报文协议ICMP、地址转换协议ARP、反向地址转换协议RARP,在网络层                                         Keepalived在网络层采用最常见的工作方式是通过ICMP协议向服务器集群中的每一个节点发送一个ICMP数据包(有点类似与Ping的功能),如果                                      某个节点没有返回响应数据包,那么认为该节点发生了故障,Keepalived将报告这个节点失效,并从服务器集群中剔除故障节点;

         在传输层: 提供了两个主要的协议:传输控制协议TCP和用户数据协议UDP,传输控制协议TCP可以提供可靠的数据输出服务、IP地址和端口,代表TCP                                        的一个连接端,要获得TCP服务,需要在发送机的一个端口和接收机的一个端口上建立连接,而Keepalived在传输层里利用了TCP协议的端口                                        连接和扫描技术来判断集群节点的端口是否正常,比如对于常见的WEB服务器80端口。或者SSH服务22端口,Keepalived一旦在传输层探测到                                      这些端口号没有数据响应和数据返回,就认为这些端口发生异常,然后强制将这些端口所对应的节点从服务器集群中剔除掉;

      在应用层:可以运行FTP,TELNET,SMTP,DNS等各种不同类型的高层协议,Keepalived的运行方式也更加全面化和复杂化,用户可以通过自定义                                             Keepalived工作方式,例如:可以通过编写程序或者脚本来运行Keepalived,而Keepalived将根据用户的设定参数检测各种程序或者服务是否                                        允许正常,如果Keepalived的检测结果和用户设定的不一致时,Keepalived将把对应的服务器从服务器集群中剔除;

      Keepalived 是运行在lvs 之上,它的主要功能是实现真实机的故障隔离及负载均衡器间的失败 切换,提高系统的可用性;

4》Keepalived体系结构

          技术分享

          

      Keepalived起初是为LVS设计的,由于Keeplalived可以实现对集群节点的状态检测,而IPVS可以实现负载均衡功能,因此,Keepalived借助于第三方模块                IPVS就可以很方便地搭建一套负载均衡系统,在这里有个误区,由于Keepalived可以和IPVS一起很好的工作,很多学员都以为Keepalived就是一个负载均衡软             件,这种理解是错误,在Keepalived当中IPVS模块是可配置的,如果需要负载均衡功能,可以在编译Keepalived时开打负载均衡功能,也可以通过编译参数关               闭, NetLINK模块主要用于实现一些高级路由框架和一些相关参数的网络功能,完成用户空间层Netlink Reflector模块发来的各种网络请求,这个图我们可以看               到用户空间层,是建立在内核空间层之上的, 

              用户空间层,主要有4个部分:

               Scheduler I/O Multiplexer 是一个I/O复用分发调度器,它负载安排Keepalived所有内部的任务请求;

               Memory Mngt 是一个内存管理机制,这个框架提供了访问内存的一些通用方法;

               Control Plane  是keepalived的控制版面,可以实现对配置文件编译和解析;

               Core componets  这部分主要保护了5个部分:

                         Watchdog:是计算机可靠领域中极为简单又非常有效的检测工具,Keepalived正是通过它监控Checkers和VRRP进程的;

                         Checkers: 这是Keepalived最基础的功能,也是最主要的功能,可以实现对服务器运行状态检测和故障隔离;

                         VRRP Stack: 这时keepalived后来引用VRRP功能,可以实现HA集群中失败切换功能;

                         IPVS wrapper: 这个是IPVS功能的一个实现,IPVS warrper模块将可以设置好的IPVS规则发送的内核空间并且提供给IPVS模块,最                                                                                终实现IPVS模块的负载功能;

                         Netlink Reflector:用来实现高可用集群Failover时虚拟IP(VIP)的设置和切换 ;

          Netlink Reflector的所有请求最后都发送到内核空间层的NETLINK 模块来完成;

5》负载均衡技术

           1>使 用负载均衡技术的理由:          

        假如我们有一个咨询类的网站,之允许100个用户同时在线访问,网站上线初期,由于知名度比较小,通常只有几个用户经常上线,后期知名度提高                    了,百度和谷歌又收录了我们的网站,于是同时在线的用户量直线上升,很快达到了上千人,于是,网站负荷加重了,经常会“反应迟钝”,这时用户开始抱                    怨,为了不影响用户对我们的信心,就一定要想办法解决这个一个问题,那么我们想想,如果有几台或者几十台相同配置的机器,前端放一个转发器,轮流转                  发客户对网站的请求,每台机器将用户数控制在100以内,那么网站的反应速度就会大大提高,即使其中的某台服务器因为硬件故障了导致宕机了,也不会                    影响用户的访问,那么其中,这个神奇的转发器就是负载均衡(Director);

          那么什么是负载均衡呢?负载均衡建立在现有的网络结构之上,它提供了一种廉价、有效、透明的方法来扩大网络设备和服务器的带宽、增加吞吐                    量、加强网络数据处理能力,以及提高网络的灵活性和可用性,通过负载均衡器,我们可以实现N台廉价的Linux服务器并行处理,从而达到小型机或者大型                 机计算能力,这也是为何负载均衡如此流行的原因;

        Scale on: 向上扩展

               所谓的向上扩展,就是把当前的服务器进行硬件升级,硬件升级带来的效果不是线性的,如果架构设计不好,那么性能不但不能提升,而且                                  还会下降;

        Scale OUT:向外扩展

               所谓的向外扩展,那么我们可以做Load Balancing:LB (负载均衡技术)

        ?          系统高可用性

        ?          系统可扩展性

        ?          负载均衡能力

      LVS+keepalived能很好的实现以上的要求,LVS提 供负载均衡,keepalived提供健康检查,故障转移,提高系统的可用性!采用这样的架构以后 很容易对                现有系统进行扩展,只要在后端添加或者减少realserver,只要更改lvs的 配置文件,并能实现无缝配置变更!

 6》Lvs模式介绍

           LVS是一个开源的软件,可以实现LINUX平台下的简单负载均衡,LVS是Linux Virtual Server的缩写,意思是Linux虚拟服务器,目前有三种IP负载均衡技                术(VS/NAT、VS/TUN和VS/DR);八种调度算法(rr,wrr,lc,wlc,lblc,lblcr,dh,sh):

      1>NAT负载模式

             技术分享

              

        NAT用法本来是因为网络IP地址不足而把内部保留IP地址通过映射转换成公网地址的一种上网方式(原地址NAT)?

        如果把NAT的过程稍微变化,就可以 成为负载均衡的一种方式?原理其实就是把从客户端发来的IP包的IP头目的地址在DR上换成其中一台                                          REALSERVER的IP地址并发至此 REALSERVER,而REALSERVER则在处理完成后把数据经过DR主机发回给客户端,DR在这个时候再把数据包的原IP地                        址改为DR接口上的 IP地址即可?期间,无论是进来的流量,还是出去的流量,都必须经DR,DR压力比较大;

      NAT模式:

          集群节点跟Direcator 必须在同一个IP网络中;

          RIP通常是私有地址,仅仅用于个集群之间通信;

          director位于Client和real server之间,并负责处理进出的所有通信;
          realservet必须将网关指向DIP,同时也支持端口影射;
          Realserver可以使用任意OS;
          在较大应用规模当中,单个Director会出现瓶颈;
          大概可以带10个左右的SERVER就会出现瓶颈。

             2>直接路由模式(DR)

            直接路由模式比较特别,很难说和什么方面相似,前NAT和TUN种模式基本上都是工作在网络层上(三层),而直接路由模式则应该是工作在数据链路                             层上(二层)?其原理 为,DR和REALSERVER都使用同一个IP对外服务?但只有DR对ARP请求进行响应,所有REALSERVER对本身这个IP的ARP请求保持                           静 默?也就是说,网关会把对这个服务IP的请求全部定向给DR,而DR收到数据包后根据调度算法,找出对应的REALSERVER,把目的MAC地址改                                         为 REALSERVER的MAC并发给这台REALSERVER?这时REALSERVER收到这个数据包,则等于直接从客户端收到这个数据包无异,处理后 直接返回给                           客户端?由于DR要对二层包头进行改换,所以DR和REALSERVER之间必须在一个广播域,也可以简单的理解为在同一台交换机上;

             技术分享

                           技术分享

                     技术分享

                                                        技术分享

             DR模式:
               每个集群节点跟dr必须在同一个物理网络(局域网)当中(dr和web不能隔了有路由器);
               VIP可以使用公网地址,实现远程管理和监控;
               director只负责处理进站请求,响应的请求封装后直接由Relserver发给客户端;
               Realserver不能将Direc当中网关。只能选择前当网关;
               Direc不能支持端口映射。VIP的端口必须和WEB服务端口一致;
               大多数的操作系统都可以应用在relserver上;
               Direc性能必NAT要好很多。处理速度提高N倍;

      3>TUN负载模式 IP隧道模式           

          隧道模式则类似于VPN的方式,使用网络分层的原理,在从客户端发来的数据包的基础上,封装一个新的IP头标记(不完整的IP头,只有目的IP部)发                                   给 REALSERVER,REALSERVER收到后,先把DR发过来的数据包的头给解开,还原其数据包原样,处理后,直接返回给客户端,而不需要再经过 DR?需要注                          意的是,由于REALSERVER需要对DR发过来的数据包进行还原,也就是说必须支持IPTUNNEL协议?所以,在REALSERVER 的内核中,必须编译支持                                    IPTUNNEL这个选项?IPTUNNEL也在Net working options里面;

        TUN模式: 

          集群节点可以跨越互联网;
             Relserver的RIP必须是公网地址(真实环境中);
             Director紧处理进站请求;
               由Relserver直接响应客户端;
                OS必须支持隧道协议,不支持端口映射;

 7》LVS负载均衡的八种调度算法       

    RR算法:
        LVS负载均衡算法1.轮叫调度(Round-RobinScheduling) 

    WRR算法:
        LVS负载均衡算法2.加权轮叫调度(WeightedRound-RobinScheduling)

    LC算法:
        LVS负载均衡算法3.最小连接调度(Least-ConnectionScheduling)

    WLC算法:
        LVS负载均衡算法4.加权最小连接调度(WeightedLeast-ConnectionScheduling)

    LBLC算法:
        LVS负载均衡算法5.基于局部性的最少链接(Locality-BasedLeastConnectionsScheduling)

    LBLCR算法:
        LVS负载均衡算法6.带复制的基于局部性最少链接(Locality-BasedLeastConnectionswithReplicationScheduling)

    DH算法:
        LVS负载均衡算法7.目标地址散列调度(DestinationHashingScheduling)

    SH算法:
        LVS负载均衡算法8.源地址散列调度(SourceHashingScheduling)

8》lvs+keepalived架构图

            技术分享

9》lvs持久性连接

      对于电子商务网站来说,用户在挑选商品的时候使用的是80端口来浏览的,当付款的时候则是通过443的ssl加密的方式,当然当用户挑选完商品付款的时 候,我们当然不希望                https的443跳转到另外一台REAL SERVER上,很显然应该是同一REAL SERVER才对,这时候就要用到基于防火墙标记的持久连接,通过定义端口的姻亲关系来实现。在生产环                 境中用的最多的也是PNMP即基于防火墙标记的持久 连接,好了引子就说到这下面我们就来详细说说LVS的持久连接;  

    1>PPC(Persistent Port Connections):将来自于同一个客户端对同一个集群服务的请求,始终定向至此前选定的RS;(持久端口连接)
        例如:client---->LVS(80)---->RS1 或 client---->LVS(23)---->RS2
        缺陷:期望访问不同的端口到同一台RS上,无法实现。
        配置:
            ipvsadm -A -t 172.16.100.1:80 -s rr -p 3600 
            ipvsadm -a -t 172.16.100.1:80 -r 172.16.100.10 -g -w 2 
            ipvsadm -a -t 172.16.100.1:80 -r 172.16.100.11 -g -w 2

    2>PCC(Persistent Client Connections):将来自于同一个客户端对所有端口的请求,始终定向至此前选定的RS;(持久客户端连接)
        说明:PCC是一个虚拟服务没有端口号(或者端口号为0),以"-p" 来标识服务。
        缺陷:定向所有服务,期望访问不同的Real Server无法实现。
        配置:
          ipvsadm -A -t 172.16.100.1:0 -s rr -p 3600 
          ipvsadm -a -t 172.16.100.1:0 -r 172.16.100.10 -g -w 2 
          ipvsadm -a -t 172.16.100.1:0 -r 172.16.100.11 -g -w 2

    3>PNMPP(Persistent Netfilter Marked Packet Persistence):持久防火墙标记连接,根据iptables 的规则,将对于某类服务几个不同端口的访问定义为一                                                                                                                    类;

      先对某一特定类型的数据包打上标记,然后再将基于某一类标记的服务送到后台的 Real Server上去,后台的Real Server 并不识别这些标记。将持久和防             火墙标记结合起来就能够实现端口姻亲功能,只要是来自某一客户端的对某一特定服务(需要不同的端口)的访问都定义到同一台 Real Server上去。

    案例:一个用户在访问购物网站时同时使用HTTP(80)和HTTPS(443)两种协议,我们需要将其定义到同一台Real Server上,而其他的服务不受限制。
    配置:         

        iptables -t mangle -A PREROUTING -d 172.16.100.1 -i eth0 -p tcp --dport 80 -j MARK --set-mark 8

        iptables -t mangle -A PREROUTING -d 172.16.100.1 -i eth0 -p tcp --dport 443 -j MARK --set-mark 8

        ipvsadm -A -f 8 -s rr -p 600

        ipvsadm -a -f 8 -r 172.16.100.10 -g -w 2

        ipvsadm -a -f 8 -r 172.16.100.11 -g -w 1

     4>持久连接命令

      1.ipvsadm -A|E … -p timeout

      2.选项

      3.-p timeout 指定持久连接时长,默认为360秒,单位是秒,即6分钟

      http://www.it165.net/admin/html/201307/1565.html

10》LVS+ Keppalived的安装

 

      1>环境描述            

          LVS server1 (Master):10.0.0.202-à虚拟IP为:10.0.0.210

          LVS server2 ( Slave ) :10.0.0.203à虚拟IP为:10.0.0.210

          WEB server1: 10.0.0.201  网关为:10.0.0.254

          WEB server2; 10.0.0.204  网关为:10.0.0.254

        注意:所有集群服务器时间要一致

       2>安装LVS           

      注意此动作,否则MAKE直接报错;

        如果没有/2.6.32-279.el6.x86_64 这个目录,请安装内核开发包

        # yum -y install kernel-devel

        # ln -s /usr/src/kernels/2.6.32-279.el6.x86_64/ /usr/src/linux

        # tar -xvf ipvsadm-1.24.tar.gz

        # cd ipvsadm-1.24

        #make && make install

        # ipvsadm –L

     3>安装Keepalived            

        # tar –xvf keepalived-1.2.12.tar.gz

        #./configure --sysconf=/etc/ --with-kernel-dir=/usr/src/kernels/2.6.32-279.el6.x86_64/

          Keepalived version       : 1.2.12

          Compiler                 : gcc

          Compiler flags           : -g -O2

          Extra Lib                : -lssl -lcrypto -lcrypt

          Use IPVS Framework       : Yes 表示使用ipvs框架,也是代表启动IPVS功能

          IPVS sync daemon support : Yes 表示启动ipvs的同步功能,--disabled-lvs-sysncd此参数可以关闭。

          IPVS use libnl           : No   表示使用新的libn1版本,如果想使用新的版本,需要重新安装libn1的包

          Use VRRP Framework       : Yes 表示使用VRRP框架,这个实现keepalived高可用的必须功能

          Use VRRP VMAC            : Yes 表示使用基础VMAC接口的xmit VRRP包

          SNMP support             : No

          SHA1 support             : No

          Use Debug flags          : No

        # make && make install

        # cp /soft/keepalived-1.2.12/bin/keepalived /usr/bin/

      

        ERRR: yum install -y openssl openssl-devel

          !!! OpenSSL is not properly installed on your system. !!!

          !!! Can not include OpenSSL headers files.            !!!

       

         4>主(master)配置Keepalived配置文件              

! Configuration File for keepalived

global_defs {  #全局定义

   notification_email { #定义邮件

      alvin@126.com  #定义邮件地址

   }

   notification_email_from alvin@126.com #定义邮件地址

   smtp_server mail.126.com #邮件服务器

   smtp_connect_timeout 30 #邮件超时时间

   router_id LVS_DEVEL #route_id标识

}

 

vrrp_instance VI_1 { #定义VRR组,

    state MASTER  #定义为MASTER主

    interface eth1 #对外访问的网络接口

    virtual_router_id 100 #虚拟路由标识。注意主从要一致

    priority 100 #主从优先级,主的优先级要高于从。注意

    advert_int 1 #:广播周期秒数

    authentication {

        auth_type PASS

        auth_pass 2209

    }

    virtual_ipaddress {

        10.0.0.210 #:虚拟VIP地址,真实环境这里应该是公网IP

 }

}

virtual_server 10.0.0.210 80 { #:虚拟VIP地址 与 端口,DR架构WEB端口要和虚拟端口监听一致。否则将无法访问

    delay_loop 6 #健康检查时间间隔,单位是秒

    lb_algo rr   #调用算法为RR

    lb_kind DR   #调用架构模式为DR

    persistence_timeout 0 #:同一IP 50秒内的请求都发到同个real server

    protocol TCP  #使用TCP协议

  

    real_server 10.0.0.201 80 {#:真实WEB服务器地址与端口

        weight 1 #:转发伐值,越高调用的越多

        TCP_CHECK {

        connect_timeout 10   #:连接超时为10秒

        nb_get_retry 3

        delay_before_retry 3

        connect_port 80  #连接端口为80,要和上面的保持一致

}

    }

    real_server 10.0.0.204 80 {

        weight 1

        TCP_CHECK {

        connect_timeout 10

        nb_get_retry 3

        delay_before_retry 3

        connect_port 80

        }

     }

}

       5>从(Slave)配置Keepalived配置文件          

      主从配置区别:

          state BACKUP   #状态改成BACKUP

          priority 90     #优先级要低于主

        interface eth1  #网络接口注意和本机对应,

      其它的配置文件内容和主的一样

     6>配置WEBserver,所有的WEB脚本都一样            

# vim

如下:

#!/bin/bash

# Written by NetSeek

# description: Config realserver lo and apply noarp

WEB_VIP="10.0.0.210"        #:修改VIP,其它的地方不动,

 

. /etc/rc.d/init.d/functions

 

case "$1" in

start)

       ifconfig lo:0 $WEB_VIP netmask 255.255.255.255 broadcast $WEB_VIP 

       /sbin/route add -host $WEB_VIP dev lo:0

       echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore

       echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce

       echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore

       echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce

       sysctl -p >/dev/null 2>&1

       echo "RealServer Start OK"

       ;;

stop)

       ifconfig lo:0 down

       route del $WEB_VIP >/dev/null 2>&1

       echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore

       echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce

       echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore

       echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce

       echo "RealServer Stoped"

       ;;

status)

        # Status of LVS-DR real server.

        islothere=`/sbin/ifconfig lo:0 | grep $WEB_VIP`

        isrothere=`netstat -rn | grep "lo:0" | grep $web_VIP`

        if [ ! "$islothere" -o ! "isrothere" ]

        then

            echo "LVS-DR real server Stopped."

        else

            echo "LVS-DR Running."

        fi 

        ;;

*)

        # Invalid entry.

        echo "$0: Usage: $0 {start|status|stop}"

        exit 1

        ;;

esac

exit 0

11》启动WEB server的脚本         

    # ./ realserver.sh start

    # ip add list

        1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN

            link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

            inet 127.0.0.1/8 scope host lo

            inet 10.0.0.210/32 brd 10.0.0.210 scope global lo:0  是否有VIP?

            inet6 ::1/128 scope host

 12》启动LVS         

    在LVS主从服务器上启动LVS

      # /etc/init.d/keepalived start

    在MASTER服务器上会看到VIP,当MASTER挂了之后。VIP将自动切换到SLAVE(从),

      # /etc/init.d/keepalived start

      eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000

          link/ether 00:0c:29:8c:4c:ec brd ff:ff:ff:ff:ff:ff

          inet 10.0.0.202/16 brd 10.0.255.255 scope global eth1

          inet 10.0.0.210/32 scope global eth1 是否有VIP? 有则OK

          inet6 fe80::20c:29ff:fe8c:4cec/64 scope link

          valid_lft forever preferred_lft forever

 13》访问测试       

  是否可以看到WEBIP

    # ipvsadm -L

      IP Virtual Server version 1.2.1 (size=4096)

      Prot LocalAddress:Port Scheduler Flags

        -> RemoteAddress:Port           Forward Weight ActiveConn InActConn

      TCP  10.0.0.210:http rr

        -> 10.0.0.204:http              Route   1      0          0        

        -> 10.0.0.201:http              Route   1      0          0      

    然后通过浏览器访问:http://10.0.0.210 看看是否可以访问?

    配置文件里面设置了同一IP,50秒内定为一台WEBserver保证数据的完整连接;

LVS+Keepalived

标签:sof   configure   web服务   ip协议   debug   ima   dmi   forward   高性能   

原文地址:http://www.cnblogs.com/xiaocheche/p/7689432.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!