基于keepalived、vip实现高可用nginx (centos)
基于keepalived、vip实现高可用nginx (centos)
1、安装keepalived
yum install keepalived
2、选同一局域网空置ip作vip
我这里测试是:
主:192.168.163.134
副:192.168.163.135
vip:192.168.163.140
3、keepalived配置
nginx检测脚本 (两台用一样脚本即可)
#!/bin/bash# 检查 Nginx 主进程是否存在(通过绝对路径匹配)
if ! pgrep -f "/usr/local/nginx/sbin/nginx" >/dev/null; then# 如果 Nginx 未运行,尝试重启(可选)/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf || exit 1sleep 1 # 等待重启完成# 再次检查,如果仍失败则返回错误pgrep -f "/usr/local/nginx/sbin/nginx" || exit 1
fi
exit 0
主vim /etc/keepalived/keepalived.conf
global_defs {router_id LVS_DEVEL
}# 添加 Nginx 健康检查脚本配置
vrrp_script chk_nginx {script "/etc/keepalived/check_nginx.sh"interval 2 # 每2秒检查一次weight -20 # 如果脚本返回非0,优先级降低20(确保备节点接管)fall 2 # 连续2次失败才认为故障rise 1 # 1次成功就认为恢复
}vrrp_instance VI_1 {state MASTER #主节点interface ens33 ## 绑定虚拟IP的网络接口(网卡),与本机IP地址所在的网络接口相同(我这里是eth0)virtual_router_id 140 ## 虚拟路由ID号(主备节点一定要相同)priority 100mcast_src_ip 192.168.163.134 ## 本机ip地址advert_int 1 # 组播信息发送间隔,俩个节点必须配置一致,默认1sauthentication {auth_type PASSauth_pass 123456}virtual_ipaddress {192.168.163.140 ## 虚拟ip,可以指定多个}# 关联 Nginx 检查脚本track_script {chk_nginx}
}
副vim /etc/keepalived/keepalived.conf
global_defs {router_id LVS_DEVEL
}# 添加 Nginx 健康检查脚本配置
vrrp_script chk_nginx {script "/etc/keepalived/check_nginx.sh"interval 2 # 每2秒检查一次weight -20 # 如果脚本返回非0,优先级降低20(确保备节点接管)fall 2 # 连续2次失败才认为故障rise 1 # 1次成功就认为恢复
}vrrp_instance VI_1 {state BACKUP #从节点interface ens33 ## 绑定虚拟IP的网络接口(网卡),与本机IP地址所在的网络接口相同(我这里是eth0)virtual_router_id 140 ## 虚拟路由ID号(主备节点一定要相同)priority 95mcast_src_ip 192.168.163.135 ## 本机ip地址advert_int 1 # 组播信息发送间隔,俩个节点必须配置一致,默认1sauthentication {auth_type PASSauth_pass 123456}virtual_ipaddress {192.168.163.140 ## 虚拟ip,可以指定多个}# 关联 Nginx 检查脚本track_script {chk_nginx}
}
配置好重启keepalived
systemctl restart keepalived
检测命令:
ip addr
测试方法:停掉nginx/直接stop keepalived
4、同理
mysql、k8s等也可基于如此实现高可用