前几天做zabbix监控supervisorctl status的程序运行状态,获取RUNNING的状态,如果配置是RUNNING,就返回结果为1,如果非RUNNING,就返回为0
测试过程中,不管怎么执行,本地执行都很正常,就是zabbix获取的时候,就是一个非正常值,排查了很久,认为zabbix获取的有问题,经排查,发现是zabbix执行supervisorctl status时没有权限,所以返回的值就不正常了,
报错如下:
error: <class ‘socket.error‘>, [Errno 13] Permission denied: file: /usr/lib64/python2.7/socket.py line: 224
故障原因:
从表面上看,好像是文件没权限,加权限也解决不了,其实是zabbix去调用supervisorctl status的时候,使用的是zabbix用户,所以没有权限,我没试过去授权zabbix,我的解决方法是如下
- #!/bin/bash```
- file=/usr/local/zabbix/etc/zabbix_agentd.conf.d/supervisorctl.txt
- case $1 in
- redis)
- REDIS=
grep "redis" $file |awk ‘{print $2}‘
- if [ "$REDIS" == "RUNNING" ];then
- echo "2"
- else
- echo "1"
- fi
- ;;
- *)
- echo "USAGE: $0 [ redis | motorroom ]"
- esac
就是先将supervisorctl status值输出到/supervisorctl.txt文件中,然后通过脚本去获取这个文件中的内容,来做到获值,这样就不存在权限的报错
原文地址:http://blog.51cto.com/zhongliang/2156598
时间: 2024-11-08 07:44:28