Keepalived + Nginx 实现高可用

安装 Keepalived

bash 复制代码
yum install -y keepalived

编辑配置文件

bash 复制代码
vi /etc/keepalived/keepalived.conf

(1)编辑 MASTER(主)节点配置文件

bash 复制代码
! Configuration File for keepalived

# 全局配置
global_defs {
   # 路由ID,不能重复,通常为 hostname
   router_id 192.168.1.116
}

# keepalived会定时执行脚本并对脚本执行的结果进行分析,动态调整vrrp_instance的优先级。
# 如果脚本执行结果为0,并且weight配置的值大于0,则优先级相应的增加。
# 如果脚本执行结果非0,并且weight配置的值小于 0,则优先级相应的减少。
# 其他情况,维持原本配置的优先级,即配置文件中priority对应的值。
vrrp_script chk_nginx {
    # 检测 nginx 状态的脚本路径
    script "/etc/keepalived/nginx_check.sh"
    # #每2秒运行一次上面的脚本
    interval 2
    # 失败一次,将自己的优先级-20,如果MASTER的priority=100,BACKUP的priority=70
    # 那么MASTER要失败2次后变为60,低于BACKUP的70,MASTER节点会降级为BACKUP,而BACKUP节点升级为MASTER
    weight -20
}

# 定义实例
vrrp_instance VI_1 {
    # 可选值为 MASTER 或 BACKUP
    state MASTER
    # 本机IP地址所在网卡名称,因为使用bond0做了双网卡绑定,所以此处配置bond0
    interface bond0
    # 虚拟路由ID,MASTER和BACKUP必须一致。这里遇到过坑,局域网内还有一套独立的Keepalived集群如果virtual_router_id值相同会冲突。
    # 同一个集群内的两台机器必须相同,但是不同的集群virtual_router_id值不能相同,如果使用了相同的virtual_router_id,它们会被视为同一个集群的成员。
    virtual_router_id 57
    # 定义优先级,数字越大优先级越高,MASTER的优先级必须大于BACKUP的优先级
    priority 100
    # 设置MASTER与BACKUP负载均衡之间同步检测的时间间隔,单位(秒)
    advert_int 1
    # 设置验证类型和密码,两个节点必须一致
    authentication {
        # 认证方式,此处PASS表示为密码
        auth_type PASS
        # 设置6位随机密码
        auth_pass 123456
    }
    # 配置浮动IP地址
    virtual_ipaddress {
        192.168.1.26
    }
    # 执行脚本
    track_script {
        # 对应vrrp_script配置的脚本
        chk_nginx
    }
}

(2)编辑 BACKUP(备)节点配置文件

bash 复制代码
! Configuration File for keepalived

# 全局配置
global_defs {
   # 路由ID,不能重复,通常为 hostname
   router_id 192.168.1.117
}

# keepalived会定时执行脚本并对脚本执行的结果进行分析,动态调整vrrp_instance的优先级。
# 如果脚本执行结果为0,并且weight配置的值大于0,则优先级相应的增加。
# 如果脚本执行结果非0,并且weight配置的值小于 0,则优先级相应的减少。
# 其他情况,维持原本配置的优先级,即配置文件中priority对应的值。
vrrp_script chk_nginx {
    # 检测 nginx 状态的脚本路径
    script "/etc/keepalived/nginx_check.sh"
    # #每2秒运行一次上面的脚本 pwd
    interval 2
    # 失败一次,将自己的优先级-20,如果MASTER的priority=100,BACKUP的priority=70
    # 那么MASTER要失败2次后变为60,低于BACKUP的70,MASTER节点会降级为BACKUP,而BACKUP节点升级为MASTER
    weight -20
}

# 定义实例
vrrp_instance VI_1 {
    # 可选值为 MASTER 或 BACKUP
    state BACKUP
    # 本机IP地址所在网卡名称,因为使用bond0做了双网卡绑定,所以此处配置bond0
    interface bond0
    # 虚拟路由ID,MASTER和BACKUP必须一致。这里遇到过坑,局域网内还有一套独立的Keepalived集群如果virtual_router_id值相同会冲突。
    # 同一个集群内的两台机器必须相同,但是不同的集群virtual_router_id值不能相同,如果使用了相同的virtual_router_id,它们会被视为同一个集群的成员。
    virtual_router_id 57
    # 定义优先级,数字越大优先级越高,MASTER的优先级必须大于BACKUP的优先级
    priority 90
    # 设置MASTER与BACKUP负载均衡之间同步检测的时间间隔,单位(秒)
    advert_int 1
    # 设置验证类型和密码,两个节点必须一致
    authentication {
        # 认证方式,此处PASS表示为密码
        auth_type PASS
        # 设置6位随机密码
        auth_pass 123456
    }
    # 配置浮动IP地址
    virtual_ipaddress {
        192.168.1.26
    }
    # 执行脚本
    track_script {
        # 对应vrrp_script配置的脚本
        chk_nginx
    }
}

(3) 编写 Nginx 状态检测脚本

bash 复制代码
vi /etc/keepalived/nginx_check.sh

这里换成其他组件,比如mysql 修改为 pgrep -c mysql 即可。

bash 复制代码
#!/bin/bash
# keepalived会定时执行脚本并对脚本执行的结果进行分析,动态调整vrrp_instance的优先级。
# 如果脚本执行结果为0,并且weight配置的值大于0,则优先级相应的增加。
# 如果脚本执行结果非0,并且weight配置的值小于0,则优先级相应的减少。
# 其他情况,维持原本配置的优先级,即配置文件中priority对应的值。
# 返回0(表示成功),返回非0值(表示失败)
# 这条命令是统计nginx进程个数
count=$(pgrep -cx nginx)
if [ "$count" -eq 0 ]
then
    echo 'nginx server is died'
    exit 1
else
    echo 'nginx server is running'
    exit 0
fi

给脚本添加执行权限

bash 复制代码
chmod +x /etc/keepalived/nginx_check.sh

(5) 启动 Keepalived

bash 复制代码
# 启动
systemctl start keepalived.service
# 重启
systemctl restart keepalived.service
# 停止
systemctl stop keepalived.service
# 查看运行状态
systemctl status keepalived
# 查看运行进程
ps -ef|grep keepalived
相关推荐
驾驭人生6 小时前
ASP.NET Core 实现 SSE 服务器推送|生产级实战教程(含跨域 / Nginx / 前端完整代码)
服务器·前端·nginx
Linux运维技术栈6 小时前
生产环境Certbot泛域名证书全自动续期完整配置指南(Cloudflare DNS验证)
nginx·证书·ssl
SeSs IZED7 小时前
【Nginx 】Nginx 部署前端 vue 项目
前端·vue.js·nginx
wuyikeer15 小时前
Nginx反向代理出现502 Bad Gateway问题的解决方案
运维·nginx·gateway
LSL666_15 小时前
nginx——方向代理和负载均衡
运维·nginx·负载均衡·反向代理
语戚15 小时前
Nginx vs Ribbon:负载均衡的两种核心范式(反向代理 vs 客户端负载)
java·nginx·spring·spring cloud·面试·ribbon·负载均衡
芳草萋萋鹦鹉洲哦1 天前
【windows】nginx如何注册为开机自启的服务(WinSW实现)
运维·windows·nginx
LSL666_1 天前
云服务上安装nginx
java·运维·nginx
刘~浪地球2 天前
Nginx + Tomcat 整合实战(五):性能优化与缓存策略
nginx·性能优化·tomcat