keepalived+nginx双机热备高可用

**

安装nginx

**
https://blog.csdn.net/qq_38553950/article/details/115914614

按照上述步骤安装完成后
修改两个nginx的首页,以便于区分访问

vim /usr/share/nginx/html/index.html

分别访问对应的ip地址
在这里插入图片描述
在这里插入图片描述

安装keepalived

yum intall -y keepalived

如果安装有报错:
Error: Package: 1:net-snmp-agent-libs-5.7.2-49.el7_9.1.x86_64 (updates) Requires: libmysqlclient.so.18(libmysqlclient_18)(64bit)

wget https://repo.mysql.com/yum/mysql-5.7-community/el/7/x86_64/mysql-community-libs-compat-5.7.34-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-compat-5.7.34-1.el7.x86_64.rpm
#rm -rf mysql-community-libs-compat-5.7.34-1.el7.x86_64.rpm

重新执行keepalived安装命令
在这里插入图片描述
修改keepalived配置文件

vi /etc/keepalived/keepalived.conf

主节点配置


vrrp_script check_haproxy{
        script "/etc/keepalived/check_haproxy_alive_not.sh"  #检测nginx脚本地址
        interval 2
        weight -20
}

vrrp_instance VI_1 { #定义实例
    state MASTER #状态参数 master/backup
    interface ens33 #虚拟VIP放置的网卡名
    virtual_router_id 52 #同一家族要一直,同一个集群id一致
    priority 100 # 优先级决定是主还是备    越大越优先
    advert_int 1 #主备通讯时间间隔
    authentication {
        auth_type PASS
        auth_pass 1111 #密码
    }
        track_script {
                check_haproxy
        }

    virtual_ipaddress {
        192.168.88.200   #虚拟VIP
    }
}

从节点配置:


vrrp_script check_haproxy{
        script "/etc/keepalived/check_haproxy_alive_not.sh"
        interval 2
        weight -20
}

vrrp_instance VI_1 {
    state BACKUP
    interface ens33
    virtual_router_id 52
    priority 99
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
        track_script {
                check_haproxy
        }

    virtual_ipaddress {
        192.168.88.200
    }
}

创建check_haproxy_alive_not.sh执行脚本

vi /etc/keepalived/check_haproxy_alive_not.sh

脚本内容如下:

#!/bin/bash
LOG_FILE="/etc/keepalived/log/haproxy-check.log"
date "+%Y-%m-%d %H:%M:%S" >> $LOG_FILE

A=`ps -C haproxy --no-header | wc -l`

echo "check haproxy status" >> $LOG_FILE
# 判断haproxy是否宕机,如果宕机尝试重新启动
if [ $A -eq 0 ];then
      echo "haproxy -f /etc/haproxy/haproxy.cfg" >> $LOG_FILE
      haproxy -f /etc/haproxy/haproxy.cfg
      # 等待3秒检查nginx 如果没有启动成功 则停止keepalived 启动备用机
      sleep 5
      if [ `ps -C haproxy --no-header |wc -l` -eq 0 ];then
        echo "start haproxy failed, pkill -9 keepalived" >> $LOG_FILE
        pkill -9 keepalived
      fi
fi

保存后赋予执行权限

chmod +x /etc/keepalived/check_haproxy_alive_not.sh

防火墙必须开启组播策略,否则集群间不能通信,虚拟IP不能飘移
centos7使用一下命令:

firewall-cmd --direct --permanent --add-rule ipv4 filter INPUT 0 --in-interface ens33 --destination 224.0.0.18 --protocol vrrp -j ACCEPT
firewall-cmd --reload

ens33是指的服务器的网卡名称,INPUT代表接收224.0.0.18的报文,使用 ip a 命令查看.

-----------------------------------------------
centos6系统 使用iptable修改策略:
vi /etc/sysconfig/iptables 添加以下编码

-A INPUT -p 112 -d 224.0.0.18/32 -j ACCEPT

-----------------------------------------------

-p 112指定协议为112,也可-p vrrp即vrrp,keepalived组播地址是224.0.0.18

启动keepalived

#启动keepalived
systemctl restart keepalived
#查看keepalived状态
systemctl status keepalived

查看IP

ip addr

在这里插入图片描述
在这里插入图片描述
访问设置的虚拟IP 192.168.88.100
在这里插入图片描述
杀死146的keepalived
在这里插入图片描述
查看147的IP信息(VIP已漂移过来)
在这里插入图片描述
重新访问虚拟IP地址
在这里插入图片描述
重新启动146的keepalived再进行访问
在这里插入图片描述

在这里插入图片描述

安装成功点个赞不过分吧

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值