已经部署好的zabbix监控系统,可参考之前的文章(使用docker-compose快速部署zabbix监控系统)进行快速部署。
vim docker_find.sh
#!/bin/bash
name_json="{\"data\":["
A='1'
docker_name=$(docker ps -a | grep -v 'STATUS' | awk '{printf $NF "\n"}')
docker_num=$(docker ps -a | grep -v 'STATUS' | awk '{printf $NF "\n"}' | wc -l)
for do_name in ${docker_name}
do
if [[ $A = ${docker_num} ]];then
name_json+="{\"{#DOCKER_NAME}\": \"${do_name}\"}"
else
name_json+="{\"{#DOCKER_NAME}\": \"${do_name}\"},"
fi
((A++))
done
name_json+="]}"
echo $name_json
这个脚本旨在输出一个json格式的数据,标准格式为:
{"data":[{"#aaa": "AAAA"},{....},{"#ccc": "CCC"}]}
ZABBIX会根据收到的这个数据,来创建监控项。
vim docker_health_status.sh
#!/bin/bash docker_name="$1" docker_num=$(docker ps -a | grep -w "${docker_name}" | wc -l) if [[ ! "${docker_num}" = 1 ]];then docker ps -a | grep -w "${docker_name}" > /tmp/.docker.txt cat /tmp/.docker.txt | while read docker_file do docker_if=$(echo ${docker_file}| awk '{printf $NF "\n"}') if [[ ${docker_if} = ${docker_name} ]];then docker_status=$(echo ${docker_file} | awk -F 'ago' '{printf $2 "\n"}' | awk '{printf $1 "\n"}') if [[ ${docker_status} = "Up" ]];then docker_health=$(echo ${docker_file} | grep "health") if [[ ${docker_health:-"nohealthcheck"} = "nohealthcheck" ]];then echo '1' else health_status=$(echo ${docker_file} | awk -F 'ago' '{printf $2 "\n"}' | awk -F ')' '{printf $NR "\n"}' | awk -F '(' '{printf $2 "\n"}') if [[ ${health_status} = 'healthy' ]];then echo '1' else echo '0' fi fi else echo '0' fi else continue fi done else docker_status=$(docker ps -a | grep -w "${docker_name}" | awk -F 'ago' '{printf $2 "\n"}' | awk '{printf $1 "\n"}') if [[ ${docker_status} = "Up" ]];then docker_health=$(docker ps -a | grep -w "${docker_name}" | grep "health") if [[ ${docker_health:-"nohealthcheck"} = "nohealthcheck" ]];then echo '1' else health_status=$(docker ps -a | grep -w "${docker_name}" | awk -F 'ago' '{printf $2 "\n"}' | awk -F ')' '{printf $NR "\n"}' | awk -F '(' '{printf $2 "\n"}') if [[ ${health_status} = 'healthy' ]];then echo '1' else echo '0' fi fi else echo '0' fi fi
这个脚本是将上一个脚本获取的docker容器名,查找对应的容器,判断容器的运行状态(包括配置了docker健康检查探针)并返回一个值:0和1。
其中1表示运行正常,0表示异常
这是使用zabbix agent客户端进行docker的自动发现并监控其运行状态,制作完后,可将其配置及脚本一同打包进zabbix agent快速部署包中(zabbix agent快速部署包制作),后续安装便会自带此自动发现功能,只需要给主机关联上该模板即可使用。
vim zabbix_agentd.conf
增加下图配置:
1是拓展配置文件路径,方便管理;
2是打开参数传递限制。
然后到刚拓展的路径下面定义docker状态的键值文件:
自定义键值格式:UserParameter=键值[*],执行脚本
创建自定义键值中的脚本路径,同时将脚本移动到该脚本路径。
上面定义了路径:/usr/local/zabbix_agent/scripts/
创建好路径,复制脚本,然后给予启动权限。
查看docker.sock权限
普通用户无权限,授权
systemctl restart zabbix_agentd.service
创建一个新的模板,点击自动发现。
然后创建自动发现规则
名称自定义,选择类型为zabbix客户端,键值填上面定义的容器发现的键值
添加完成后如图:
然后点击添加监控项原型,创建监控项原型
名称自定义,选择类型为zabbix客户端,键值填上面定义的容器状态的键值
添加完成后如图所示:
然后点击触发器原型
创建触发器原型
这里选择last,问题表达式的值=0,恢复表达式的值=1
选择要监测docker容器运行的主机并关联模板
然后点击自动发现,选择,立刻执行
查看监控项,成功发现并监控
上面是使用zabbix agent客户配置的自动发现监控。还可以使用外部检查的方式进行配置,下一篇文章将会发布使用外部检查的方式进行配置。
若是大家对本文有何疑问和建议,请大家评论留言,小菜鸡会随时关注,谢谢!
错误信息