利用keepalived实现主/从和主/主模式的高性能负载均衡集群

要求:

1、使用nginx的反向代理功能实现负载均衡

2、keepalived实现高可用

       第一组的虚拟地址为172.16.1.100

            D设备的优先级高

       第二组的虚拟地址为172.16.1.110

            E设备的优先级高

3、分别实现主/从和主/主两种配置

 

集群拓扑:

     利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第1张图片

第一种:主/从配置

所有配置之前先在各个主机上进行时间同步

 ntpdate 时间服务器地址

一、后端real server(A、B、C)配置

   1、在A、B、C三台主机上安装httpd包

    yum install httpd

   2、配置虚拟主机

       vim /etc/httpd/conf.d/vir.conf    

      A主机:    

       利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第2张图片

     B主机

       利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第3张图片

     C主机

        利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第4张图片

   3、创建三主机的URL 目录及主页面

   A主机

     mkdir  -pv /data/web/

         vim /data/web/index.html

         内容为 This is Vhost1

   B主机

     mkdir  -pv /data/web/

         vim /data/web/index.html

         内容为 This is Vhost2

   C主机

     mkdir  -pv /data/web/

         vim /data/web/index.html

         内容为 This is Vhost3

注意:三主机主页面不同,是为了后面实验来区分不同的real server

启动httpd服务: systemctl  start  httpd.service

二、配置负载均衡节点

         D(此主机为MASTER)

  E(此主机为BACKUP)主机

  利用nginx的ngx_http_upsteam_module模块实现负载均衡

1、安装nginx包

            在D、E主机上分别安装

            yum install nginx

2、配置负载均衡

           在D、E主机上分别安装

   vim /etc/nginx/nginx.conf

   定义websvr组:

    upstream websvr {

          server 192.168.70.137:80;

          server 192.168.70.138:80;

          server 192.168.70.140:80;

         }

   反向代理组 websvr

       location / {

             proxy_pass http://websvr;

        }

    利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第5张图片

三、配置keepalived服务

      1、全局配置

  主机D上

  利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第6张图片

         主机E上配置

         利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第7张图片

     2、分别在两个主机上定义脚本 chk_down

         此脚本的功能:

            文件 /etc/keepalived/down 存在时:虚拟IP转义到另一个节点

         vrrp_script chk_down {

              script “[[ -f /etc/keepalived/down ]] && exit 1 || exit 0”

               interval 1

               weight -10

            }

      3、分别在两个主机上定义脚本 chk_ngx

         此脚本功能:

           确认nginx服务是否正运行

          vrrp_script chk_ngx {

              script “killall -0 nginx && exit 0 || exit 1”

              interval 1

              weight -10

              fall 2

              rise 1

          }

          利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第8张图片

      4、vrrp_instance配置

         D主机

         利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第9张图片

        E主机

        利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第10张图片

     5、创建notify警告配置脚本

         分别在两个主机上创建

         vim  /etc/keepalived/notify.sh

          利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第11张图片

         chmod +x notify.sh 给予此脚本执行权限

6、启动服务

  systemctl start keepalived.service

四、测试

  1、不做修改时,即主机D上没有/etc/keepalived/down文件

      (1)、查看虚拟IP位置

            在主机D上(此主机为MASTER)

             利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第12张图片

    在主机E上(此主机为BACKUP)

     利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第13张图片

通过对比可以看到虚拟IP在D主机上

    (2)、查看nginx是否启动

     通过脚本/etc/keepalived/notify.sh可以看到哪台主机成为MASTER状态,哪台主机就自动启动nginx服务

    主机D

    

    主机E

    

通过对比可以知道主机D上的nginx服务启动,而主机E上的nginx服务为启动

(3)访问URL

     curl  http:/172.16.1.10

     利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第14张图片

     2、在主机D上创建/etc/keepalived/down文件

         touch  /etc/keepalived/down

        (1)、查看虚拟IP位置

            在主机D上(此主机为MASTER)

            利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第15张图片

 在主机E上(此主机为BACKUP)

            利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第16张图片

 通过对比可以看到虚拟IP在E主机上

     (2)、查看nginx是否启动

      主机D

           

             主机E上

          

       通过对比可以知道主机E上的nginx服务启动,而主机D上的nginx服务为启动

(3)访问URL

     curl  http:/172.16.1.100

         利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第17张图片

         能正常访问,现实了高性能

第二部分实现主/主配置

一、增加配置在D、E主机上

    1、 在原有的配置基础上增加一个vrrp_instance配置

        在主机D上配置

       利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第18张图片

        在主机E上配置

       利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第19张图片

    2、修改警告配置脚本

      将backup时停止nginx服务改为启动nginx服务

       利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第20张图片

二、检测

   1、不做修改时,即主机D和E上都没有/etc/keepalived/down文件

     (1)、查看虚拟IP位置

      在主机D上

      利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第21张图片

     在主机E上

      利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第22张图片

通过对比看到:

    虚拟IP:172.16.1.100在主机D上

           虚拟IP:172.16.1.110在主机E上

     (2)查看nginx服务状态

          主机D、E的nginx服务都处于启动状态

          

     (3)访问URL

      curl  http:/172.16.1.100

            利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第23张图片 

     curl  http:/172.16.1.110

             利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第24张图片

           能正常访问,现实了高性能

    2、在主机D上创建/etc/keepalived/down文件

        (1)、查看虚拟IP位置

            在主机D上

           利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第25张图片

         在主机E上

           利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第26张图片

通过对比看到:

    虚拟IP:172.16.1.100在主机E上

           虚拟IP:172.16.1.110在主机E上

     (2)查看nginx服务状态

          主机D、E的nginx服务都处于启动状态

          

     (3)访问URL

      curl  http:/172.16.1.100

            利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第27张图片 

     curl  http:/172.16.1.110

             利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第28张图片

             能正常访问,现实了高性能

    3、在主机E上创建/etc/keepalived/down文件

          (1)、查看虚拟IP位置

            在主机D上

           利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第29张图片

            在主机E上

           利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第30张图片

通过对比看到:

    虚拟IP:172.16.1.100在主机D上

           虚拟IP:172.16.1.110在主机D上

     (2)查看nginx服务状态

          主机D、E的nginx服务都处于启动状态

           

     (3)访问URL

      curl  http:/172.16.1.100

            利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第31张图片 

     curl  http:/172.16.1.110

             利用keepalived实现主/从和主/主模式的高性能负载均衡集群_第32张图片

             能正常访问,现实了高性能

你可能感兴趣的:(Linux运维之道,keepalived,nginx)