zabbix 自动发现 tomcat日志异常文件数量

简介:
+关注继续查看

1.proc.py

#/usr/bin/python

import subprocess

import os

import socket

import json

import glob

import time

import datetime

javas=[]

java_dir_proc='xx'

now = datetime.datetime.now()

strdatetime = now.strftime("%Y/%m/%d")

java_dir_home=['ip1','ip2']

def get_exception(java_dir):

a = os.listdir(java_dir)

for x in a:

#javapath = os.path.join(java_dir, x)

#if os.path.isdir(javapath):

   if len(x) != 0:

   javas.append({'{#EXCEPTION}':x.strip('\n')})

for i in java_dir_home:

    java_dir=java_dir_proc + i + '/' + strdatetime

    get_exception(java_dir)

news_javas = []

for id in javas:

    if id not in news_javas:

        news_javas.append(id)

print json.dumps({'data':news_javas},indent=4,separators=(',',':'))

2.proc_num.py

#!/usr/bin/python

import sys

import subprocess

import os

import socket

import json

import glob

import time

import datetime

zdict={}

zd=[]

javas=[]

java_dir_proc='xx'

now = datetime.datetime.now()

strdatetime = now.strftime("%Y/%m/%d")

java_dir_home=['ip1','ip2']

def get_exception(javapath):

        if os.path.isdir(javapath):

            #CMD="cd javapath && ls|wc -l"

            os.chdir(javapath)

            CMD='ls|wc -l'

            t=subprocess.Popen(CMD,shell=True,stdout=subprocess.PIPE,env=None)

            for java in t.stdout.readlines():

                if len(java) != 0:

                        S=java.strip('\n').strip(':')

                        return S

if len(sys.argv) == 2:

    argv1 = sys.argv[1]

    for i in java_dir_home:

    javapath=java_dir_proc + i + '/' + strdatetime + '/' + argv1

        zdict[i]=get_exception(javapath)

        #print zdict[i]

        zd.append(int(zdict[i]))

    print reduce(lambda x,y:x+y,zd)

else:

    print -1

3.cat check_proc_exception.conf 

UserParameter=proc.discovery,/usr/bin/python /usr/local/zabbix/bin/proc.py

UserParameter=proc.num[*],/usr/bin/python /usr/local/zabbix/bin/procnum.py $1

4.建立模板

5.其实还可以写的更好

比如

UserParameter=proc.num[*],/usr/bin/python /usr/local/zabbix/bin/procnum.py $1 $2

对应于proc.num[{#EXCEPTION},$2]

写的差,有几个地方要优化下。比如+,怎么连接字符串。

6.图像

wKiom1hc8vCi1rTPAABRsihXZe8585.png-wh_50



改进

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
7天前
|
监控 Java 应用服务中间件
zabbix监控tomcat
zabbix监控tomcat
15 0
|
4月前
|
监控 网络协议 安全
tomcat多实例优化及zabbix监控群集(二)
tomcat多实例优化及zabbix监控群集
|
4月前
|
监控 Java 应用服务中间件
tomcat多实例优化及zabbix监控群集(一)
tomcat多实例优化及zabbix监控群集
|
设计模式 监控 Java
Zabbix对Tomcat的监控
Zabbix通过java gateway 及 JMX  对Tomcat 进行监控,并实现自定义模板的导入及应用,模拟实际生产中的Tomacat性能等参数的图形监测显示。
32054 84
Zabbix对Tomcat的监控
|
运维 监控 Java
shell脚本配合zabbix实现tomcat的故障自愈
shell脚本配合zabbix实现tomcat的故障自愈 1.背景及实现方式方法 Tomcat运行JAVA类的程序代码经常会导致内存溢出,往往都是收到告警后再去处理,收到报警再处理就会拖延故障解决的时间,因此就需要靠故障自愈的机制来解决人为干预的成本。
272 0
shell脚本配合zabbix实现tomcat的故障自愈
|
监控 Java 应用服务中间件
zabbix监控tomcat的jvm内存(二十七)
zabbix监控tomcat的jvm内存 1.介绍 tomcat监控主要是jvm,又来了jvm监控我们可以看到jvm的内存使用情况,内存溢出情况 zabbix监控tomcat使用的是zabbix-java-gateway,zabbix-java-gateway需要java环境
389 0
zabbix监控tomcat的jvm内存(二十七)
|
JSON 监控 Java
zabbix精华篇-低级自动发现详解---批量自动获取主机所有tomcat端口并进行监控(二十四)
zabbix利用低级自动发现自动监控tomcat端口 1.为什么要使用自动发现 由于我们tomcat服务器特别多,且每一个上面跑的实例长达几十个,但是这些tomcat的端口也都需要监控起来,如果手动添加的话将会非常麻烦,我们可以利用自动发现,将自动发现配置一些规则并做成模板,给有tomcat的服务器链接模板就可以了,这个过程就会大大减少人工的工作量
425 0
zabbix精华篇-低级自动发现详解---批量自动获取主机所有tomcat端口并进行监控(二十四)
|
监控 Java 应用服务中间件
zabbix tomcat模板
zabbix提供了一个java gateway的应用去监控jmx(Java Management Extensions,即Java管理扩展)是一个为应用程序、设备、系统等植入管理功能的框架。
1315 0
|
监控 Java 应用服务中间件
相关产品
云迁移中心
推荐文章
更多
推荐镜像
更多