设为首页 收藏本站
查看: 748|回复: 0

[经验分享] zabbix 自动发现 tomcat日志异常文件数量

[复制链接]

尚未签到

发表于 2018-12-7 07:28:19 | 显示全部楼层 |阅读模式
  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=get_exception(javapath)
  #print zdict
  zd.append(int(zdict))
  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.图像

      改进
    #/usr/bin/python
    import subprocess
    import os
    import socket
    import json
    import glob
    import time
    import datetime
    javas=[]
    java_dir='xx'
    now = datetime.datetime.now()
    strdatetime = now.strftime("%Y/%m/%d")
    def get_exception(java_dir):
    a = os.listdir(java_dir)
    for x in a:
                if x == "nginx" or x == "api" or x.startswith('.'):
                     pass
                else:
                     javas.append({'{#EXCEPTION}': x.strip('\n')})

    if __name__ == '__main__':
        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=(',', ':'))#!/usr/bin/python
    import sys
    import subprocess
    import os
    import socket
    import json
    import glob
    import time
    import datetime
    zdict={}
    zd=[]
    javas=[]
    java_dir='xx'
    now = datetime.datetime.now()
    strdatetime = now.strftime("%Y/%m/%d")
    def get_exception(javapath):
            if os.path.isdir(javapath):
                os.chdir(javapath)
                CMD='find . -type f|wc -l'
                t=subprocess.Popen(CMD,shell=True,stdout=subprocess.PIPE,env=None)
                try:
                    for java in t.stdout.readlines():
                        if len(java) != 0:
                            S = java.strip('\n').strip(':')
                            return S
                except e:
                    return 0

    if len(sys.argv) == 3:
        argv1 = sys.argv[1]
        argv2 = sys.argv[2]
        file = '/usr/local/zabbix/scripts/tomcat.txt'
        with open(file, 'r') as f:
            for line in f.readlines():
                name = line.strip().split()[0]
                if argv1 == name:
                    ip = line.strip().split()[1]
                    log_path = os.path.join(java_dir,argv1,ip,argv2,strdatetime)
                    a_num = get_exception(log_path)
                    if a_num:
                        zd.append(int(a_num))
                    else:
                        zd.append(0)
            print reduce(lambda x, y: x + y, zd)
    else:
        print -1



  • 运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
    2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
    3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
    4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
    5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
    6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
    7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
    8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

    所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-644122-1-1.html 上篇帖子: tomcat 6线程数达到默认值(200)处理方法 下篇帖子: eclipse tomcat 启动45秒的问题
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    扫码加入运维网微信交流群X

    扫码加入运维网微信交流群

    扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

    扫描微信二维码查看详情

    客服E-mail:kefu@iyunv.com 客服QQ:1061981298


    QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


    提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


    本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



    合作伙伴: 青云cloud

    快速回复 返回顶部 返回列表