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

[经验分享] Logstash 日志采集工具

[复制链接]

尚未签到

发表于 2019-1-29 14:17:27 | 显示全部楼层 |阅读模式
      Logstash是一个开源的用于收集,分析和存储日志的工具。
      Logstash: Logstash服务的组件,用于处理传入的日志。不过是基于Elasticsearch配置使用。
      Elasticsearch: 存储所有日志。
      做个示例监控test-http、tomcat和test-api等系统的运行状态,输出error信息到elasticsearch。需要在每一台test服务器上安装配置。
      一、下载
  logstash:https://download.elastic.co/logstash/logstash/logstash-2.4.1.zip
  unzip logstash-2.4.1.zip
      二、log4j的配置
  ### 设置###
  log4j.rootLogger = debug,stdout,D,E
  ### 输出信息到控制抬 ###
  log4j.appender.stdout = org.apache.log4j.ConsoleAppender
  log4j.appender.stdout.Target = System.out
  log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
  log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
  ### 输出DEBUG 级别以上的日志到  path/logs/error.log ###
  log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
  log4j.appender.D.File = logs/log.log
  log4j.appender.D.Append = true
  log4j.appender.file.ImmediateFlush=false
  log4j.appender.file.BufferedIO=true
  log4j.appender.file.BufferSize=8192
  log4j.appender.D.Threshold = DEBUG
  log4j.appender.D.layout = org.apache.log4j.PatternLayout
  log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} %c [%t]-[%p] %m%n
  ### 输出ERROR 级别以上的日志到  path/logs/error.log ###
  log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
  log4j.appender.E.File =logs/error.log
  log4j.appender.E.Append = true
  log4j.appender.E.Threshold = ERROR
  log4j.appender.E.layout = org.apache.log4j.PatternLayout
  log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} %c [%t]-[%p] %m%n
  
      三、test系统的logstash配置,注意logs目录位置和ElasticSearch的Hosts
  # vim test-api.conf
  input {
      file {
          path => "/opt/test-api/logs/error.log"
          start_position => "beginning"
          type => "test-api"
      }
  }
  filter {
      multiline {
          pattern => "^\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2}"
          negate => true
          what => "previous"
      }
      grok {
          match => { "message" => "%{TIMESTAMP_ISO8601:datetime} %{NOTSPACE:clazz} \[%{NOTSPACE:thread-id}\]\-\[%{LOGLEVEL:level}\] %{GREEDYDATA:msg}" }
      }
  }
  output {
      elasticsearch {
          hosts => ["10.207.101.100:9200","10.207.101.101:9200","10.207.101.102:9200"]
          index => "test_logs-%{+YYYYMMdd}"
          document_type => "logs"
      }
  }
  

  # cat test-http.conf
  input {
      file {
          path => "/opt/test-http/logs/error.log"
          start_position => "beginning"
          type => "test"
      }
  }
  filter {
      multiline {
          pattern => "^\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2}"
          negate => true
          what => "previous"
      }
      grok {
          match => { "message" => "%{TIMESTAMP_ISO8601:datetime} %{NOTSPACE:clazz} \[%{NOTSPACE:thread-id}\]\-\[%{LOGLEVEL:level}\] %{GREEDYDATA:msg}" }
      }
  }
  output {
      elasticsearch {
          hosts => ["10.207.101.100:9200","10.207.101.101:9200","10.207.101.102:9200"]
          index => "test_logs-%{+YYYYMMdd}"
          document_type => "logs"
      }
  }
  

  # cat test_logs-tomcat.conf

  input {
      file {
          path => "/opt/server/tomcat/logs/web.log"
          start_position => "beginning"
          type => "tomcat"
      }
  }
  filter {
      multiline {
          pattern => "^\d{4}-\d{2}-\d{2}\s\d{2}:\d{2}:\d{2}"
          negate => true
          what => "previous"
      }
      grok {
          match => { "message" => "%{TIMESTAMP_ISO8601:datetime} \[%{NOTSPACE:thread-id}\] %{LOGLEVEL:level}\s*%{NOTSPACE:clazz} \- %{GREEDYDATA:msg}" }
      }
  }
  output {
      elasticsearch {
          hosts => ["10.207.101.100:9200","10.207.101.101:9200","10.207.101.102:9200"]
          index => "test_logs-%{+YYYYMMdd}"
          document_type => "logs"
      }
  }
  
  设置启动
  # cat  test-start.sh
  nohup bin/logstash -f test-http.conf > /dev/null 2>&1 &
  nohup bin/logstash -f test-api.conf > /dev/null 2>&1 &
  nohup bin/logstash -f test_logs-tomcat.conf > /dev/null 2>&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-669267-1-1.html 上篇帖子: beats(5) 下篇帖子: 关于动态Mappin-多字段映射
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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