nginx 搭建高可用集群

Posted 爱上口袋的天空

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了nginx 搭建高可用集群相关的知识,希望对你有一定的参考价值。

1、简介

微服务中,为防止服务提供者宕掉,提供多个服务,nginx 同样,如果只使用一个 nginx ,可能发生单点故障,导致整个微服务不可用 。

2、什么是 nginx 高可用

在这里插入图片描述

3、准备工作

  • (1)需要两台 nginx 服务器

  • (2)需要 keepalived

  • (3)需要虚拟 ip

在这里插入图片描述

1)需要两台服务器 192.168.56.20 和 192.168.56.21

2)在两台服务器安装 nginx

​ 这里如果不想再去安装一遍 Nginx ,可以直接克隆 CentOs 。

3)在两台服务器安装 keepalived

4、在两台服务器安装 keepalived

4.1)使用 yum 命令进行安装

      命令:yum install keepalived –y

4.2)安装之后,在 /etc 里面生成目录 keepalived,有文件 keepalived.conf

5、完成高可用配置(主从配置)

Keepalived + Nginx 配合使用

192.168.56.20主机 Nginx

(1)修改/etc/keepalived/keepalivec.conf 配置文件

! Configuration File for keepalived

global_defs {

    notification_email {

        acassen@firewall.loc

        failover@firewall.loc

        sysadmin@firewall.loc
     }

        notification_email_from Alexandre.Cassen@firewall.loc

        smtp_server 192.168.56.20

        smtp_connect_timeout 30

        router_id 192.168.56.20 # 主机ip地址或者主机名字
}


vrrp_script chk_http_port {
        script "/usr/local/src/nginx_check.sh"
        interval 2 #(检测脚本执行的间隔)
        weight 2 # 权重
   }
        vrrp_instance VI_1 {
        state MASTER # 备份服务器上将 MASTER 改为 BACKUP
        interface eth1 # 网卡
        virtual_router_id 51  # 主、备机的 virtual_router_id 必须相同
        priority 100  # 主、备机取不同的优先级,主机值较大,备份机值较小
        advert_int 1
        authentication {
                auth_type PASS
                auth_pass 1111
        }

        virtual_ipaddress {
             192.168.56.50 # VRRP H 虚拟地址
        }

}

  (2)  在/usr/local/src添加检测脚本:nginx_check.sh

#!/bin/bash
A=`ps -C nginx –no-header | wc -l`
if [ $A -eq 0 ];then
        /usr/bin/nginx
        sleep 2
        if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
            killall keepalived
        fi
fi

  

192.168.56.21  从机 Nginx   

(1)修改/etc/keepalived/keepalivec.conf 配置文件

! Configuration File for keepalived

global_defs {

    notification_email {

        acassen@firewall.loc

        failover@firewall.loc

        sysadmin@firewall.loc 

     }

        notification_email_from Alexandre.Cassen@firewall.loc

        smtp_server 192.168.56.20 #这里保持不变

        smtp_connect_timeout 30

        router_id 192.168.56.20 #这里保持不变
}


vrrp_script chk_http_port {
        script "/usr/local/src/nginx_check.sh"
        interval 2
        weight 2
   }
        vrrp_instance VI_1 {
        state BACKUP # 修改为从机 BACKUP
        interface eth1 # 修改为从机 ip
        virtual_router_id 51
        priority 90 # 优先级比主机低
        advert_int 1
        authentication {
            auth_type PASS
            auth_pass 1111
        }

        virtual_ipaddress {
            192.168.56.50
        }

}

(2)在/usr/local/src添加检测脚本:nginx_check.sh

#!/bin/bash
A=`ps -C nginx –no-header | wc -l`
if [ $A -eq 0 ];then
        /usr/bin/nginx
        sleep 2
        if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
            killall keepalived
        fi
fi

6、启动 Nginx

 

7、启动 keepalived

启动 keepalived命令:systemctl start keepalived.service
测试 keepalived 是否启动成功

ps -ef | grep keepalived

在这里插入图片描述 

8、最终测试

 (1)在浏览器地址栏输入 虚拟 ip 地址:http://192.168.56.50/

 此时便可以通过虚拟 ip 地址访问到 Nginx 。

(2)把主服务器(192.168.56.20)nginx 和 keepalived 停止,再输入 192.168.56.50

此时主机 192.168.56.20 宕机了,从机变为主机。 

以上是关于nginx 搭建高可用集群的主要内容,如果未能解决你的问题,请参考以下文章

Nginx+Keepalived搭建高可用负载平衡WEB 集群

六nginx 搭建高可用集群

nginx 搭建高可用集群

heartbeat+nginx搭建高可用HA集群

Nginx+Keeplived+Tomcat搭建高可用/负载均衡的web服务器集群

keepalived讲解及搭建高可用Nginx热备集群