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日志并进行多维度分析。
相关文章
|
18天前
|
Linux Shell
Linux手动清理Linux脚本日志定时清理日志和log文件执行表达式
Linux手动清理Linux脚本日志定时清理日志和log文件执行表达式
72 1
|
1月前
|
Dubbo Java 应用服务中间件
Dubbo日志文件输出到指定目录 如何定义?
Dubbo日志文件输出到指定目录 如何定义?
|
28天前
|
Shell Linux C语言
【Shell 命令集合 网络通讯 】Linux 查看系统中的UUCP日志文件 uulog命令 使用指南
【Shell 命令集合 网络通讯 】Linux 查看系统中的UUCP日志文件 uulog命令 使用指南
29 0
|
1月前
|
Linux 应用服务中间件 nginx
【PUSDN】centos查看日志文件内容,包含某个关键字的前后5行日志内容,centos查看日志的几种方法
【PUSDN】centos查看日志文件内容,包含某个关键字的前后5行日志内容,centos查看日志的几种方法
46 0
|
28天前
|
监控 Shell Linux
【Shell 命令集合 系统管理 】Linux 自动轮转(log rotation)日志文件 logrotate命令 使用指南
【Shell 命令集合 系统管理 】Linux 自动轮转(log rotation)日志文件 logrotate命令 使用指南
48 0
|
3月前
|
SQL Java 数据库连接
Mybatis之Mybatis简介、搭建Mybatis相关步骤(开发环境、maven、核心配置文件、mapper接口、映射文件、junit测试、log4j日志)
【1月更文挑战第2天】 MyBatis最初是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Software Foundation迁移到了Google Code。随着开发团队转投Google Code旗下,iBatis3.x正式更名为MyBatis。代码于2013年11月迁移到Github iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBatis提供的持久层框架包括SQL Maps和Data Access Objects(DAO)
197 3
Mybatis之Mybatis简介、搭建Mybatis相关步骤(开发环境、maven、核心配置文件、mapper接口、映射文件、junit测试、log4j日志)
|
1月前
|
Dubbo Java 应用服务中间件
Dubbo日志文件输出到指定目录 如何定义?
Dubbo日志文件输出到指定目录 如何定义?
|
1月前
|
Dubbo Java 应用服务中间件
Dubbo日志文件输出到指定目录 如何定义?
Dubbo日志文件输出到指定目录 如何定义?
|
28天前
|
监控 Shell Linux
【Shell 命令集合 系统管理 】Linux 实时监控日志文件 swatch命令 使用指南
【Shell 命令集合 系统管理 】Linux 实时监控日志文件 swatch命令 使用指南
33 1
|
1月前
|
消息中间件 测试技术 Python
Python使用多线程解析超大日志文件
Python使用多线程解析超大日志文件
20 0

推荐镜像

更多