热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

logstash收集tomcat异常信息

我所期望达到的效果,就是每个日期一条,在kibana界面也是一条。多行异常的也是一条。其实,很简单,就是加个反向判断。logstash原理一个客户端,一个服务器,就是这样的模式没什

我所期望达到的效果,就是每个日期一条,在kibana界面也是一条。多行异常的也是一条。

其实,很简单,就是加个反向判断。

logstash原理

一个客户端,一个服务器,就是这样的模式

没什么神奇的,最麻烦的正则匹配,不好弄。听说storm更好用。

1.client配置

cat /etc/logstash/conf.d/shipper.conf

input {
    file {
        path => ["/opt/src/logs/*/*/*/*"]
        type => "service"
        start_position => "beginning"
    }
}
filter {
  if [type] == "service" {
      multiline {
          patterns_dir => "/etc/logstash/conf.d"
          pattern => "(^%{MYTIMESTAMP})"
          negate => true
          what => "previous"
      }
      }
  grok {
        patterns_dir => "/etc/logstash/conf.d"
        match => [ "message", "%{MYLOG}" ]
        add_field => [ "log_ip", "随便写" ]
  }
}
output {
        stdout {}
        redis {
        host => "你的服务端ip"
        port => 6379
        password => "8ff35947f8efe8db806622f6a98a1ea3"
        data_type => "list"
        key => "key_count"
    }
}

patterns_dir => "/etc/logstash/conf.d" 这个东西就是正则表达式

新建一个文件 cat /etc/logstash/conf.d/j2ee

JAVACLASS (?:[a-zA-Z$_][a-zA-Z$_0-9]*\.)*[a-zA-Z$_][a-zA-Z$_0-9]*
HTTPPORT  ([a-zA-Z$_0-9]*\-)*([0-9])
JAVALOGMESSAGE (.*)
MYTIMESTAMP 20%{YEAR}-%{MONTHNUM}-%{MONTHDAY}%{HOUR}:%{MINUTE}:%{SECOND}
MYLOG %{MYTIMESTAMP:mytimestamp}\s\[%{HTTPPORT:port}\]\s%{LOGLEVEL:level}\s%{JAVACLASS:class}\s-%{JAVALOGMESSAGE:logmessage}

我的日志格式是这样的

2016-10-2015:52:01.174 [http-apr-8282-exec-4] INFO  c.e.w.c.WorkFlowRestController -resp:

如果你的日志不一样,那么j2ee文件要做相应的修改

http://grokdebug.herokuapp.com/ 这个网站可以测试

比如

技术分享

启动脚本logstash.sh

#!/bin/bash
. /etc/init.d/functions
function start(){
cd /home/
nohup /opt/logstash/bin/logstash -f /etc/logstash/conf.d/shipper.conf & >>/dev/null 2>&1
}
function stop(){
kill -9 `ps -ef|grep logstash|grep -v grep|awk ‘{print $2}‘`
}
case $1 in
start)
start
;;
stop)
stop
;;
*)
printf "Usage sh *.sh start|stop"
;;
esac

sh logstash.sh stop/start

2.server配置

cat /etc/logstash/conf.d/indexer.conf

input {
    redis {
        host => "172.29.12.193"
        port => 6379
        password => "8ff35947f8efe8db806622f6a98a1ea3"
        type => "redis-input"
        data_type => "list"
        key => "key_count"
    }
}
 
output {
    stdout {}
    elasticsearch {
        cluster => "elasticsearch"
        codec => "json"
        protocol => "http"
        }
}

3.kibana效果

技术分享


多行为一行就不截图了

本文出自 “人,要有自己的想法” 博客,请务必保留此出处http://szgb2016.blog.51cto.com/340201/1863975

logstash 收集tomcat异常信息


推荐阅读
  • 本文详细介绍了Java代码分层的基本概念和常见分层模式,特别是MVC模式。同时探讨了不同项目需求下的分层策略,帮助读者更好地理解和应用Java分层思想。 ... [详细]
  • iOS snow animation
    CTSnowAnimationView.hCTMyCtripCreatedbyalexon1614.Copyright©2016年ctrip.Allrightsreserved.# ... [详细]
  • 本文整理了一份基础的嵌入式Linux工程师笔试题,涵盖填空题、编程题和简答题,旨在帮助考生更好地准备考试。 ... [详细]
  • packagecom.panchan.tsmese.utils;importjava.lang.reflect.ParameterizedType;importjava.lang. ... [详细]
  • 本文详细介绍了 Java 网站开发的相关资源和步骤,包括常用网站、开发环境和框架选择。 ... [详细]
  • 小程序的授权和登陆
    小程序的授权和登陆 ... [详细]
  • 本文详细介绍了Linux系统中用于管理IPC(Inter-Process Communication)资源的两个重要命令:ipcs和ipcrm。通过这些命令,用户可以查看和删除系统中的消息队列、共享内存和信号量。 ... [详细]
  • 为什么多数程序员难以成为架构师?
    探讨80%的程序员为何难以晋升为架构师,涉及技术深度、经验积累和综合能力等方面。本文将详细解析Tomcat的配置和服务组件,帮助读者理解其内部机制。 ... [详细]
  • 操作系统如何通过进程控制块管理进程
    本文详细介绍了操作系统如何通过进程控制块(PCB)来管理和控制进程。PCB是操作系统感知进程存在的重要数据结构,包含了进程的标识符、状态、资源清单等关键信息。 ... [详细]
  • 基于iSCSI的SQL Server 2012群集测试(一)SQL群集安装
    一、测试需求介绍与准备公司计划服务器迁移过程计划同时上线SQLServer2012,引入SQLServer2012群集提高高可用性,需要对SQLServ ... [详细]
  • Nacos 0.3 数据持久化详解与实践
    本文详细介绍了如何将 Nacos 0.3 的数据持久化到 MySQL 数据库,并提供了具体的步骤和注意事项。 ... [详细]
  • malloc 是 C 语言中的一个标准库函数,全称为 memory allocation,即动态内存分配。它用于在程序运行时申请一块指定大小的连续内存区域,并返回该区域的起始地址。当无法预先确定内存的具体位置时,可以通过 malloc 动态分配内存。 ... [详细]
  • 一、Tomcat安装后本身提供了一个server,端口配置默认是8080,对应目录为:..\Tomcat8.0\webapps二、Tomcat8.0配置多个端口,其实也就是给T ... [详细]
  • NX二次开发:UFUN点收集器UF_UI_select_point_collection详解
    本文介绍了如何在NX中使用UFUN库进行点收集器的二次开发,包括必要的头文件包含、初始化和选择点集合的具体实现。 ... [详细]
  • 解决SQL Server数据库sa登录名无法连接的问题
    在安装SQL Server数据库后,使用Windows身份验证成功,但使用SQL Server身份验证时遇到问题。本文将介绍如何通过设置sa登录名的密码、启用登录名状态以及开启TCP协议来解决这一问题。 ... [详细]
author-avatar
w手机用户2736240235dOD
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有