Keepalived监测脚本一直不执行
今天在搭建Nginx+Keepalived集群时,启动Keepalievd发现检查脚本不执行,脚本本身是没有问题的。
1.1 监测脚本
- 脚本如下:
A=`ps -C nginx --no-header |wc -l`
if [ $A -eq 0 ];then
/root/nginx/sbin/nginx
if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
killall keepalived
fi
fi
其实出现这个问题也有很多人是因为脚本本身就运行不起来。建议先测试自身脚本是否有问题。如果有问题就换成我的吧,亲测有效。
- 测试监测脚本是否有效:
1.2 问题解决
1.2.1 关闭selinux
其实真正的罪魁祸首是selinux
(具体是啥意思,有兴趣的同学可以百度)。
我只要把它关闭就行了:
setenforce 0
然后再次启动keepalived,检查nginx是否有启动(检查脚本是否执行):
systemctl start keepalived.service
1.2.2 永久关闭selinux
刚刚那个操作只是暂时性的关闭selinux
,我们重启机器之后,selinux又会重新开启。
- 我们可以永久关闭
sed -i "s/^SELINUX=.*/SELINUX=disabled/g" /etc/selinux/config
然后记得重启机器。
1.3 其他情况
当然,除了我以上的情况会导致监测脚本的不执行,还有一些其他情况。如:
1)你的检查脚本名字对不上!!!!!!
- keepalived.conf:
vrrp_script check_nginx {
script "/root/nginx_check.sh"
interval 1
}
vrrp_instance VI_1 {
nopreempt
state BACKUP
interface ens33
virtual_router_id 6
priority 120
advert_int 1
master_down_interval 10
virtual_ipaddress {
192.168.222.188
}
track_script {
check_ng # 你上面定义的名字叫check_nginx !!!你这样又写check_ng!!!
}
}
2)script里面检查脚本名字和文件名不一样,或者路径错了!!!!!!!!!
vrrp_script check_nginx {
script "/root/nginx_check.sh" # 这里一定要检查检查再检查!!!!!是否和你自己存放的教程脚本路径一致!!!!!!!
interval 1
}
vrrp_instance VI_1 {
nopreempt
state BACKUP
interface ens33
virtual_router_id 6
priority 120
advert_int 1
master_down_interval 10
virtual_ipaddress {
192.168.222.188
}
track_script {
check_nginx # 你上面定义的名字叫check_nginx !!!你这样又写check_ng!!!
}
}
以上都是由于疏忽导致的错误。大家切记切记