由于需要服务保持全年无间断服务,通过使用url页面返回200,则认定服务正常运行,通过此方法,来判断服务是否正常运行。
正常的tomcat健康状态监控页面如下图
我们利用如下命令判断返回值是否为200
shell>/usr/bin/curl -o /dev/null -s --connect-timeout 5 -w '%{http_code}' http://10.0.0.107:9100/sms-app/health
倘若返回值不为200,则断定服务异常,报警
如下内容
cat >/etc/zabbix/WEB.txt <<EOF
10.0.0.107:9000/sms-admin/health 10.0.0.107:9100/sms-app/health 10.0.0.107:9090/auditServer/health 10.0.0.107:7711/pushControl/health 10.0.0.107:7700/sendService/health 10.0.0.107:6003/pa/health 10.0.0.107:8513/sms/health 10.0.0.107:7712/pushControl/health 10.0.0.107:7725/reply-server/health 10.0.0.107:2222/mDNServer/health EOF
cat >/etc/zabbix/scripts/web_site_code_status.sh <<EOF
#!/bin/bash # function:monitor tcp connect status from zabbix source /etc/bashrc >/dev/null 2>&1 source /etc/profile >/dev/null 2>&1 #/usr/bin/curl -o /dev/null -s -w %{http_code} http://$1/ web_site_discovery () { WEB_SITE=($(cat /etc/zabbix/WEB.txt|grep -v "^#")) printf '{ ' printf ' "data":[ ' for((i=0;i<${#WEB_SITE[@]};++i)) { num=$(echo $((${#WEB_SITE[@]}-1))) if [ "$i" != ${num} ]; then printf " { " printf " "{#SITENAME}":"${WEB_SITE[$i]}"}, " else printf " { " printf " "{#SITENAME}":"${WEB_SITE[$num]}"}]} " fi } } web_site_code () { /usr/bin/curl -o /dev/null -s --connect-timeout 5 -w '%{http_code}' $1 } case "$1" in web_site_discovery) web_site_discovery ;; web_site_code) web_site_code $2 ;; *) echo "Usage:$0 {web_site_discovery|web_site_code [URL]}" ;; esac EOF
root@DL-test2:zabbix# grep '^[a-Z]' zabbix_agentd.conf
PidFile=/var/run/zabbix/zabbix_agentd.pid LogFile=/var/log/zabbix/zabbix_agentd.log LogFileSize=0 Server=10.0.0.113 ServerActive=10.0.0.113 Hostname=DL-test2 Include=/etc/zabbix/zabbix_agentd.d/*.conf #此项打开
cat >/etc/zabbix/zabbix_agentd.d/web_site_discovery.conf <<EOF
UserParameter=web.site.discovery,/bin/bash /etc/zabbix/scripts/web_site_code_status.sh web_site_discovery UserParameter=web.site.code[*],/bin/bash /etc/zabbix/scripts/web_site_code_status.sh web_site_code $1 EOF #/bin/bash 此项必须要加上,不然有可能找不到命令,导致脚本命令无法被zabbix-agent调用
模板详见附件
直接在模板里导入附件模板
启动zabbix-agent
会在被监控主机的触发器中发现我们需要监控的tomcat
停止6003端口的服务,我们会发现如下图所示报警
然后启动6003服务后,服务监控正常。
至此自动发现tomcat服务状态,部署完毕。
tomcat 端口 8005 被 windows 系统服务占用导致启动闪退的问题