上一节我们配置了Keepalived,实现了高可用。这是我们master主节点nginx所在主机整个挂掉的情况。那么如果我们的master主节点的主机里面仅仅只有nginx挂掉,Keepalived还是继续会在master主节点上运行。继续访问就会出现无法访问此网站的情况。
所以,为了实现7*24小时不间断的为用户提供服务,所以我们就要让keepalived组件定时的检测nginx。如果检测到nginx停掉了,我们就要重启nginx,使nginx重新恢复正常,如果nginx实在启动不了的话,再切换到backup从节点的nginx。
cd /etc/keepalived
1、增加Nginx重启检测脚本
vim /etc/keepalived/check_nginx_alive_or_not.sh
#!/bin/bash
A=`ps -C nginx --no-header |wc -l`
# 判断nginx是否宕机,如果宕机了,尝试重启
if [ $A -eq 0 ];then
/usr/local/nginx/sbin/nginx
# 等待一小会再次检查nginx,如果没有启动成功,则停止keepalived,使其启动备用机
sleep 3
if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
killall keepalived
fi
fi
增加运行权限
chmod +x /etc/keepalived/check_nginx_alive_or_not.sh
2、配置keepalived监听nginx脚本
vrrp_script check_nginx_alive {
script "/etc/keepalived/check_nginx_alive_or_not.sh"
interval 2 # 每隔两秒运行上一行脚本
weight 10 # 如果脚本运行成功,则升级权重+10
# weight -10 # 如果脚本运行失败,则升级权重-10
}
3、在vrrp_instance
中新增监控的脚本
track_script {
check_nginx_alive # 追踪 nginx 脚本
}
4、重启Keepalived使得配置文件生效
systemctl restart keepalived