keepalived+lvs-dr实现高可用负载均衡

keepalived+lvs-dr实现高可用负载均衡

实验拓扑

keepalived+lvs-dr实现高可用负载均衡

实验要求

  1. RS1与RS2地址为172.18.27.201/202
  2. VS1和VS2地址为172.18.27.103/200,VIP为172.18.27.254
  3. VS1和VS2实现lvs-dr负载均衡及高可用性,且vs为sorry sever。
  4. keepalived是单主模式。

    实验步骤

  5. 各个主机安装必备软件

    ##RS1与RS2安装httpd
    yum install -y httpd
    ##VS1与VS2安装keeplived和httpd
    yum instll keepalived httpd -y 
    ##所有主机同步时间
    ntpdate 2.cn.pool.ntp.org
  6. 配置RS1与RS2

    RS1配置,RS1的系统为centos7.2.
    ##配置测试页
    vim /var/www/html/index.html
    <h1/>R1:172.18.27.201</h1>
    ##启动httpd服务
    systemctl restart httpd.service
    ##配置VIP,并关闭内核中的arp_ignore,建议写脚本
    [root@localhost bin]#vi setparam.sh           
    #!/bin/bash
    vip="172.18.27.254"
    start (){
         ifconfig lo:0 $vip netmask 255.255.255.255 broadcast $vip up
         echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
         echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce
         echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
         echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore
         route add -host $vip dev lo:0
    }
    stop (){
         echo 0 > /proc/sys/net/ipv4/conf/all/arp_announce
         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/lo/arp_ignore
         ifconfig lo:0 down
    }
    case $1 in
    start)
         start
         echo "arp_announce set ok"
         echo "arp_ignore set ok"
         echo "lo:0 up"
         ;;
    stop)
         stop
         echo "arp_announce set ok"
         echo "arp_ignore set ok"
         echo "lo:0 down"
         ;;
    *)
         echo "$0 stop|start"
         ;;
    esac
    RS2配置,RS1的系统为centos7.2。
    ##配置测试页
    vim /var/www/html/index.html
    <h1/>R2:172.18.27.202</h1>
    ##启动httpd服务
    systemctl restart httpd.service
    ##用RS1的脚本配置RS2
  7. 配置VS1和VS2

    ##VS1配置,VS1系统是centos6.8。
    #配置sorry_server
    yum install -y httpd
    vim /var/www/html/index.html
    <h1/>sorry server 1:172.18.27.102</h1>
    启动服务
    srvice httpd start
    #配置keepalived
    vim /etc/keepalived/keepalived.conf
    ! Configuration File for keepalived 
    global_defs { 
         notification_email {                            ##报警邮箱设置
                 root@localhost                            ##报警邮箱
         }
         notification_email_from keepalived@localhost    ##报警有哪个用户发送
         smtp_server 127.0.0.1                            ##报警邮箱服务器
         smtp_connect_timeout 30                            ##报警超时时间
         vrrp_mcast_group4 224.100.27.1                    ##通过组播地址,通告状态和优先级等信息
    }
    vrrp_instance VI_1 {                                    ##设置vrrp
     state MASTER                                        ##设置主从
     interface eth1                                        ##vrrp实例工作的网络接口
     virtual_router_id 51                                ##设置vrrp的id标识符,0-255
     priority 100                                        ##设定优先级
     advert_int 1                                        ##对外的通知时间间隔
     authentication {                                    ##设定认证方式
         auth_type PASS
         auth_pass 1111
     }
     track_interface {                                    ##设定监听网络接口
         eth1
     }   
     nopreempt                                            ##设定是否为抢占和非抢占模式
     virtual_ipaddress {                                    ##定义VIP
         172.18.27.254/16 dev eth1 label eth1:0            ##设定VIP在那个网络接口上
     }  
    }   
    virtual_server 172.18.27.254 80 {                        
         delay_loop 6                                    ##定义服务轮询间隔,多久检查RS的健康状态
         lb_algo wrr                                        ##设定VS的调用方法
         lb_kind DR                                        ##设定lvs的调用类型
         protocol TCP                                    ##设定工作的协议
         sorry_server 127.0.0.1 80                        ##设定sorry_server
         real_server 172.18.27.201 80 {                    ##设定RS
                 weight 1                                ##设定权重
                 HTTP_GET {                                ##设定RS健康状态查询方法
                         url {                            根据urlde状态码来确定RS的状态
                                 path /
                                 status_code 200
                         }
                 connect_timeout 1                        ##设定检查的超时时长
                 nb_get_retry 3                            ##设定检查的重试次数
                 delay_before_retry 1                    ##设定检查延迟时间
    
                 }
         }
         real_server 172.18.27.202 80 {
                 weight 2
                 HTTP_GET {
                         url {
                                 path /  
                                 status_code 200
                         }
                 connect_timeout 1
                 nb_get_retry 3
                 delay_before_retry 1    
    
                 }
         }
    } 
    #启动服务
    service keepalived start
    ##配置VS2,VS2的系统是centOS7.2.
    #配置sorry_server
    yum install -y httpd
    vim /var/www/html/index.html
    <h1/>sorry server 2:172.18.27.200</h1>
    启动服务
    systemctl start httpd
    #配置keepalived
    ! Configuration File for keepalived
    global_defs { 
         notification_email {
                 root@localhost
         }
         notification_email_from keepalived@localhost
         smtp_server 127.0.0.1
         smtp_connect_timeout 30
         vrrp_mcast_group4 224.100.27.1
    }
    vrrp_instance VI_1 {
     state BACKUP
     interface eno16777736
     virtual_router_id 51
     priority 100
     advert_int 1
     authentication {
         auth_type PASS
         auth_pass 1111
     }
     track_interface {
         eno16777736
     }   
     nopreempt
     virtual_ipaddress {
         172.18.27.254/16 dev eno16777736 label eno16777736:0
     }
    }   
    virtual_server 172.18.27.254 80 {
         delay_loop 6
         lb_algo wrr
         lb_kind DR
         net_mask 255.255.0.0
         protocol TCP
         sorry_server 127.0.0.1 80
         real_server 172.18.27.201 80 {
                 weight 1
                 HTTP_GET {
                         url {
                                 path /
                                 status_code 200
                         }
                 connect_timeout 1
                 nb_get_retry 3
                 delay_before_retry 1
                 }
         }
         real_server 172.18.27.202 80 {
                 weight 2
                 HTTP_GET {
                         url {
                                 path /  
                                 status_code 200
                         }
                 connect_timeout 1
                 nb_get_retry 3
                 delay_before_retry 1                 
                 }
         }
    } 
    #启动服务
    systemctl start keeplived

    测试实验效果

    在client测试实验效果
    for i in {1..10};do curl 172.18.27.254 ;done
    正常状态的测试效果

    keepalived+lvs-dr实现高可用负载均衡

    一台RS挂掉之后

    keepalived+lvs-dr实现高可用负载均衡

    两台RS都挂掉

    keepalived+lvs-dr实现高可用负载均衡

原创文章,作者:oranix,如若转载,请注明出处:http://www.178linux.com/75627

(0)
oranixoranix
上一篇 2017-05-14 22:27
下一篇 2017-05-15 08:44

相关推荐

  • 网卡名称更改

    网卡是计算机进行网络通信的必须的设备。在CentOS6及其更早的系统中,网卡设备在系统中的名称命名为eth#(#为0,1,2…之类的数字)。在内核版本为3.0.0及其以后的Linux发行版中,网卡设备在系统中名称变得很长,变得不好识别以及不利于管理。为了更好的管理,我们将新的网络设备命名改为传统的命名。 网卡名称更改 在CentOS系统中操作 在RHEL7系…

    Linux干货 2016-11-23
  • Linux学习之课前环境安装调试

    系统安装,VNC,VMware软件安装

    2018-03-26
  • Linux基础目录名称命名法则及功用规定

    FHS:文件系统层级结构标准 – Filesystem Hieracry Standard 参考这篇文档: http://refspecs.linuxfoundation.org/FHS_2.3/fhs-2.3.html  /bin:供所有用户使用的基本命令文件 /sbin:系统管理使用的工具程序 /boot:引导加载器必须用的静态文件…

    Linux干货 2016-08-15
  • N25-第一周作业

    第一周作业 一 、计算机的组成及其功能 计算机由CPU,控制器,存储器,输入设备,输出设备组成的。 CPU是计算机的重要硬件之一,主要负责运算和指令解释。 控制器是控制计算机系统的各个硬件设备协同工作的如(主板的南桥,北桥等) 存储器分为内存和硬盘,内存负责程序运行,硬盘负责数据存储。 输入设备有键盘,鼠标等。 输出设备有显示器,打印机等。 二 、…

    Linux干货 2016-12-04
  • 简单描述LVS工作原理-第1部分

    一、NAT模式(VS-NAT) 原理:就是把客户端发来的数据包的IP头的目的地址,在负载均衡器上换成其中一台RS的IP地址,并发至此RS来处理,RS处理完成后把数据交给经过负载均衡器,负载均衡器再把数据包的原IP地址改为自己的IP,将目的地址改为客户端IP地址即可。期间,无论是进来的流量,还是出去的流量,都必须经过负载均衡器。 优点:集群中的物理服务器可以使…

    Linux干货 2016-08-15