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

要求:

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

2、keepalived实现高可用

       第一组的虚拟地址为172.16.1.100

            D设备的优先级高

       第二组的虚拟地址为172.16.1.110

            E设备的优先级高

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

集群拓扑:

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

第一种:主/从配置

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

 ntpdate 时间服务器地址

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

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

    yum install httpd

   2、配置虚拟主机

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

      A主机:

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

     B主机

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

     C主机

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

   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实现主/从和主/主模式的高性能负载均衡集群

三、配置keepalived服务

      1、全局配置

  主机D上

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

         主机E上配置

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

     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实现主/从和主/主模式的高性能负载均衡集群

      4、vrrp_instance配置

         D主机

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

        E主机

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

     5、创建notify警告配置脚本

         分别在两个主机上创建

         vim  /etc/keepalived/notify.sh

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

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

6、启动服务

  systemctl start keepalived.service

四、测试

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

      (1)、查看虚拟IP位置

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

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

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

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

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

    (2)、查看nginx是否启动

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

    主机D

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

    主机E

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

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

(3)访问URL

     curl  http:/172.16.1.10

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

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

         touch  /etc/keepalived/down

        (1)、查看虚拟IP位置

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

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

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

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

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

     (2)、查看nginx是否启动

      主机D

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

             主机E上

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

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

(3)访问URL

     curl  http:/172.16.1.100

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

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

第二部分实现主/主配置

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

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

        在主机D上配置

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

        在主机E上配置

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

    2、修改警告配置脚本

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

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

二、检测

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

     (1)、查看虚拟IP位置

      在主机D上

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

     在主机E上

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

通过对比看到:

    虚拟IP:172.16.1.100在主机D上

           虚拟IP:172.16.1.110在主机E上

     (2)查看nginx服务状态

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

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

     (3)访问URL

      curl  http:/172.16.1.100

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

     curl  http:/172.16.1.110

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

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

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

        (1)、查看虚拟IP位置

            在主机D上

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

         在主机E上

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

通过对比看到:

    虚拟IP:172.16.1.100在主机E上

           虚拟IP:172.16.1.110在主机E上

     (2)查看nginx服务状态

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

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

     (3)访问URL

      curl  http:/172.16.1.100

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

     curl  http:/172.16.1.110

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

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

 

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

          (1)、查看虚拟IP位置

            在主机D上

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

            在主机E上

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

通过对比看到:

    虚拟IP:172.16.1.100在主机D上

           虚拟IP:172.16.1.110在主机D上

     (2)查看nginx服务状态

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

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

     (3)访问URL

      curl  http:/172.16.1.100

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

     curl  http:/172.16.1.110

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

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

 

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

(0)
zqzq
上一篇 2017-06-25
下一篇 2017-06-25

相关推荐

  • 【26期】Linux第六周学习小总结

        时光匆匆,一周时光悠然而逝,带给我们的只有知识的充实,和每日强大的自信心,学习的日益深入,慢慢的然我们的思绪和状态带回高中时光,吃饭上课睡觉三点一线的生活,枯燥中透露出稍微的晨曦,让每个明天都充满着期待,那我们的本周的学习中磁盘管理算是占了很大的比重,毕竟关于磁盘的知识很是难理解,那我就把本周的知识回顾温习,同时分享给大家。 &n…

    2017-08-19
  • ​N22-℡浮生.若夢 ╮第五周作业

    1、显示当前系统上root、fedora或user1用户的默认shell; ~]# grep -E "^(root|user1|fedora)" /etc/passwd |cut -d: -f1,7 root:/bin/bash user1:/bin/bash fedo…

    Linux干货 2016-10-09
  • raid介绍

    raid介绍 在生产环境中,服务器所需的存储容量比较大,一般都会选择磁盘阵列来走存储。 阵列的优点 多个磁盘合成一个“阵列”来提供更好的性能、冗余,或者两者都提供 首先在I/O能力上,多个磁盘并行读写,可以提高读写的速度。 阵列所提供的磁盘冗余,提升存储设配的耐用性。 RAID实现的 外接式磁盘阵列:通过扩展卡提供适配能力 内接式RAID:主板集成RAID控…

    2017-06-24
  • Linux基础之LVM

    一.LVM介绍 LVM(Logic Volume Management)逻辑卷管理器,其基本原理就是将多个磁盘的分区在逻辑上进行组合,使之成为一个大容量的磁盘进行使用,可以实现动态的分配存储空间。 LVM基本模型以及基本术语,如下图所示: PV:物理卷,从逻辑上与磁盘分区具有同样功能的设备 VG:卷组,由一个或多个物理卷组成 LV:逻辑卷,具有逻辑边界的存储…

    Linux干货 2016-11-09
  • vsftpd

    vsftpd:     程序环境:         配置文件:/etc/vsftpd/vsftpd.conf         主程序:/usr/sbin/vsf…

    Linux干货 2016-12-05
  • RAID简介

    RAID是什么? RAID英文名字叫Redundant Arrays of Independent Disks,也叫磁盘阵列?阵列有是什么意思?通俗的理解就是把很多的硬盘组织在一起来使用。       RAID可以根据性能来划分为两种:有无冗余(容错)能力     &n…

    Linux干货 2016-02-14