zoukankan      html  css  js  c++  java
  • Logstash 基础入门

    原文地址:Logstash 基础入门
    博客地址:http://www.extlight.com

    image

    一、前言

    Logstash 是一个开源的数据收集引擎,它具有备实时数据传输能力。它可以统一过滤来自不同源的数据,并按照开发者的制定的规范输出到目的地。

    顾名思义,Logstash 收集数据对象就是日志文件。由于日志文件来源多(如:系统日志、服务器 日志等),且内容杂乱,不便于人类进行观察。因此,我们可以使用 Logstash 对日志文件进行收集和统一过滤,变成可读性高的内容,方便开发者或运维人员观察,从而有效的分析系统/项目运行的性能,做好监控和预警的准备工作等。

    二、安装

    Logstash 依赖 JDK1.8 ,因此在安装之前请确保机器已经安装和配置好 JDK1.8。

    Logstash 下载

    1. tar -zxvf logstash-5.6.3.tar.gz -C /usr
    2. cd logstash-5.6.3

    三、组成结构

    Logstash 通过管道进行运作,管道有两个必需的元素,输入和输出,还有一个可选的元素,过滤器。

    输入插件从数据源获取数据,过滤器插件根据用户指定的数据格式修改数据,输出插件则将数据写入到目的地。如下图:

    image

    我们先来一个简单的案例:

    1. bin/logstash -e 'input { stdin { } } output { stdout {} }'

    启动 Logstash 后,再键入 Hello World,结果如下:

    1. [root@localhost logstash-5.6.3]# bin/logstash -e 'input { stdin { } } output { stdout {} }'
    2. Sending Logstash's logs to /usr/logstash-5.6.3/logs which is now configured via log4j2.properties
    3. [2017-10-27T00:17:43,438][INFO ][logstash.modules.scaffold] Initializing module {:module_name=>"fb_apache", :directory=>"/usr/logstash-5.6.3/modules/fb_apache/configuration"}
    4. [2017-10-27T00:17:43,440][INFO ][logstash.modules.scaffold] Initializing module {:module_name=>"netflow", :directory=>"/usr/logstash-5.6.3/modules/netflow/configuration"}
    5. [2017-10-27T00:17:43,701][INFO ][logstash.pipeline ] Starting pipeline {"id"=>"main", "pipeline.workers"=>1, "pipeline.batch.size"=>125, "pipeline.batch.delay"=>5, "pipeline.max_inflight"=>125}
    6. [2017-10-27T00:17:43,744][INFO ][logstash.pipeline ] Pipeline main started
    7. The stdin plugin is now waiting for input:
    8. [2017-10-27T00:17:43,805][INFO ][logstash.agent ] Successfully started Logstash API endpoint {:port=>9600}
    9. Hello World
    10. 2017-10-27T07:17:51.034Z localhost.localdomain Hello World

    Hello World(输入)经过 Logstash 管道(过滤)变成:2017-10-27T07:17:51.034Z localhost.localdomain Hello World (输出)。

    在生产环境中,Logstash 的管道要复杂很多,可能需要配置多个输入、过滤器和输出插件。

    因此,需要一个配置文件管理输入、过滤器和输出相关的配置。配置文件内容格式如下:

    1. # 输入
    2. input {
    3. ...
    4. }
    5. # 过滤器
    6. filter {
    7. ...
    8. }
    9. # 输出
    10. output {
    11. ...
    12. }

    根据自己的需求在对应的位置配置 输入插件过滤器插件输出插件 和 编码解码插件 即可。

    四、插件用法

    在使用插件之前,我们先了解一个概念:事件。

    Logstash 每读取一次数据的行为叫做事件。

    在 Logstach 目录中创建一个配置文件,名为 logstash.conf(名字任意)。

    4.1 输入插件

    输入插件允许一个特定的事件源可以读取到 Logstash 管道中,配置在 input {} 中,且可以设置多个。

    修改配置文件:

    1. input {
    2. # 从文件读取日志信息
    3. file {
    4. path => "/var/log/messages"
    5. type => "system"
    6. start_position => "beginning"
    7. }
    8. }
    9. # filter {
    10. #
    11. # }
    12. output {
    13. # 标准输出
    14. stdout { codec => rubydebug }
    15. }

    其中,messages 为系统日志。

    保存文件。键入:

    1. bin/logstash -f logstash.conf

    在控制台结果如下:

    1. {
    2. "@version" => "1",
    3. "host" => "localhost.localdomain",
    4. "path" => "/var/log/messages",
    5. "@timestamp" => 2017-10-29T07:30:02.601Z,
    6. "message" => "Oct 29 00:30:01 localhost systemd: Starting Session 16 of user root.",
    7. "type" => "system"
    8. }
    9. ......

    4.2 输出插件

    输出插件将事件数据发送到特定的目的地,配置在 output {} 中,且可以设置多个。

    修改配置文件:

    1. input {
    2. # 从文件读取日志信息
    3. file {
    4. path => "/var/log/error.log"
    5. type => "error"
    6. start_position => "beginning"
    7. }
    8. }
    9. # filter {
    10. #
    11. # }
    12. output {
    13. # 输出到 elasticsearch
    14. elasticsearch {
    15. hosts => ["192.168.2.41:9200"]
    16. index => "error-%{+YYYY.MM.dd}"
    17. }
    18. }

    其中,error.log 的内容格式如下:

    1. 2017-08-04 13:57:30.378 [http-nio-8080-exec-1] ERROR c.g.a.global.ResponseResultAdvice -设备数据为空
    2. com.light.pay.common.exceptions.ValidationException: 设备数据为空
    3. at com.light.pay.common.validate.Check.isTrue(Check.java:31)
    4. at com.light.attendance.controllers.cloudApi.DevicePushController.deviceInfoPush(DevicePushController.java:44)
    5. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    6. at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    7. at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
    8. at java.lang.Thread.run(Thread.java:745)
    9. 2017-08-04 13:57:44.495 [http-nio-8080-exec-2] ERROR c.g.a.global.ResponseResultAdvice -Failed to invoke remote method: pushData, provider: dubbo://192.168.2.100:20880/com.light.attendance.api.DevicePushApi?application=salary-custom&default.check=false&default.timeout=30000&dubbo=2.8.4&interface=com.light.attendance.api.DevicePushApi&methods=getAllDevices,getDeviceById,pushData&organization=com.light.attendance&ow
    10. ......

    配置文件中使用 elasticsearch 输出插件。输出的日志信息将被保存到 Elasticsearch 中,索引名称为 index 参数设置的格式。

    如果读者不了解 Elasticsearch 基础内容,可以查看本站 《Elasticsearch 基础入门》 文章或自行百度进行知识的补缺。

    保存文件。键入:

    1. bin/logstash -f logstash.conf

    打开浏览器访问 http://192.168.2.41:9100 使用 head 插件查看 Elasticsearch 数据,结果如下图:

    image

    踩坑提醒:
    file 输入插件默认使用 “ ” 判断日志中每行的边界位置。error.log 是笔者自己编辑的错误日志,之前由于在复制粘贴日志内容时,忘记在内容末尾换行,导致日志数据始终无法导入到 Elasticsearch 中。 在此,提醒各位读者这个关键点。

    4.3 编码解码插件

    编码解码插件本质是一种流过滤器,配合输入插件或输出插件使用。

    从上图中,我们发现一个问题:Java 异常日志被拆分成单行事件记录到 Elasticsearch 中,这不符合开发者或运维人员的查看习惯。因此,我们需要对日志信息进行编码将多行事件转成单行事件记录起来。

    我们需要配置 Multiline codec 插件,这个插件可以将多行日志信息合并成一行,作为一个事件处理。

    Logstash 默认没有安装该插件,需要开发者自行安装。键入:

    1. bin/logstash-plugin install logstash-codec-multiline

    修改配置文件:

    1. input {
    2. # 从文件读取日志信息
    3. file {
    4. path => "/var/log/error.log"
    5. type => "error"
    6. start_position => "beginning"
    7. # 使用 multiline 插件
    8. codec => multiline {
    9. # 通过正则表达式匹配,具体配置根据自身实际情况而定
    10. pattern => "^d"
    11. negate => true
    12. what => "previous"
    13. }
    14. }
    15. }
    16. # filter {
    17. #
    18. # }
    19. output {
    20. # 输出到 elasticsearch
    21. elasticsearch {
    22. hosts => ["192.168.2.41:9200"]
    23. index => "error-%{+YYYY.MM.dd}"
    24. }
    25. }

    保存文件。键入:

    1. bin/logstash -f logstash.conf

    使用 head 插件查看 Elasticsearch 数据,结果如下图:

    image

    4.4 过滤器插件

    过滤器插件位于 Logstash 管道的中间位置,对事件执行过滤处理,配置在 filter {},且可以配置多个。

    本次测试使用 grok 插件演示,grok 插件用于过滤杂乱的内容,将其结构化,增加可读性。

    安装:

    1. bin/logstash-plugin install logstash-filter-grok

    修改配置文件:

    1. input {
    2. stdin {}
    3. }
    4. filter {
    5. grok {
    6. match => { "message" => "%{IP:client} %{WORD:method} %{URIPATHPARAM:request} %{NUMBER:bytes} %{NUMBER
    7. :duration}" }
    8. }
    9. }
    10. output {
    11. stdout {
    12. codec => "rubydebug"
    13. }
    14. }

    保存文件。键入:

    1. bin/logstash -f logstash.conf

    启动成功后,我们输入:

    1. 55.3.244.1 GET /index.html 15824 0.043

    控制台返回:

    1. [root@localhost logstash-5.6.3]# bin/logstash -f logstash.conf
    2. Sending Logstash's logs to /root/logstash-5.6.3/logs which is now configured via log4j2.properties
    3. [2017-10-30T08:23:20,456][INFO ][logstash.modules.scaffold] Initializing module {:module_name=>"fb_apache", :directory=>"/root/logstash-5.6.3/modules/fb_apache/configuration"}
    4. [2017-10-30T08:23:20,459][INFO ][logstash.modules.scaffold] Initializing module {:module_name=>"netflow", :directory=>"/root/logstash-5.6.3/modules/netflow/configuration"}
    5. [2017-10-30T08:23:21,447][INFO ][logstash.pipeline ] Starting pipeline {"id"=>"main", "pipeline.workers"=>1, "pipeline.batch.size"=>125, "pipeline.batch.delay"=>5, "pipeline.max_inflight"=>125}
    6. The stdin plugin is now waiting for input:
    7. [2017-10-30T08:23:21,516][INFO ][logstash.pipeline ] Pipeline main started
    8. [2017-10-30T08:23:21,573][INFO ][logstash.agent ] Successfully started Logstash API endpoint {:port=>9600}
    9. 55.3.244.1 GET /index.html 15824 0.043
    10. {
    11. "duration" => "0.043",
    12. "request" => "/index.html",
    13. "@timestamp" => 2017-10-30T15:23:23.912Z,
    14. "method" => "GET",
    15. "bytes" => "15824",
    16. "@version" => "1",
    17. "host" => "localhost.localdomain",
    18. "client" => "55.3.244.1",
    19. "message" => "55.3.244.1 GET /index.html 15824 0.043"
    20. }

    输入的内容被匹配到相应的名字中。

    五、参考资料

  • 相关阅读:
    zoj 3693, 卡精度
    zoj 3690, 计数 dp , 快速幂
    hdu 1496,枚举
    zoj 2399, 哈弗曼编码
    poj 2560,mst
    poj 2007, 乱搞,计算几何
    bnu 29064, 期望 水题
    img,bg
    垂直居中,定位的方法
    .reverse ,join,split区分
  • 原文地址:https://www.cnblogs.com/xd502djj/p/9244213.html
Copyright © 2011-2022 走看看