利用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 21:40
下一篇 2017-06-25 23:42

相关推荐

  • 第十二周作业

    1、请描述一次完整的http请求处理过程;     1)建立或处理连接:接收请求或拒绝请求;     2)接收请求:接收来自于网络的请求报文中对某资源的一次请求的过程;接收请求的方式通常是并发访问响应模型;     3)处理请求:对请求报文进行解析,并获取请求的资源及请求方法等相关信息,解析后的报文…

    2017-03-27
  • Linux基础知识之脚本初级编程

    1.编程语言的分类:机器语言,汇编语言,高级语言     高级语言:         静态语言:编译型语言 在程序执行之前就会编译成机器代码(完全转化完成)       &nbsp…

    Linux干货 2016-08-15
  • sed使用详解

    vim  ,sed 1.首先,sed作为一个流编译器,它是对文本进行处理的,它和grep虽然都是对文本进行处理的,但是sed的处理机制和grep还是有很大的不同的,grep:文本过滤(模式:pattern)工具;grep, egrep, fgrep(不支持正则表达式搜索)sed:stream editor,文本编辑工具;awk:Linux上的实现g…

    Linux干货 2016-08-11
  • 自己做一个CA

    构建CA服务器    CA配置文件位置:        /etc/pki/tls/openssl.cfg           &n…

    Linux干货 2017-04-11
  • Linux 文本处理,文本工具,查看,分析,统计文本文件,grep,正则表达式

    文本处理 各种文本工具,查看,分析,统计文本文件 grep 正则表达式 扩展正则表达式 sed cat -n f1 加行号(空格行都计算) cat -b f1 加行号(只计算有字符的行) cat -ns f1 加行号(压缩空行) cat -v f1 能看windows文件的M`符号 cat -T f1 能够显示里面的tab空位,显示为^I cat -A f1…

    Linux干货 2016-08-07
  • 文件系统挂载

    挂载: 将额外文件系统与根文件系统某现存的目录建立起关联关系,进而使得此目录做为其它文件访问入口的行为 卸载: 为解除此关联关系的过程 把设备关联挂载点:mount Point mount 卸载时:可使用设备,也可以使用挂载点 umount mount   umount命令都是临时生效,机器重启后失效 挂载点下原有文件在挂载完成…

    Linux干货 2017-04-30