Logstash(1)执行流程及使用原因,和工作原理

概述及执行流程

集中、转换和存储数据

官方文字说明:Logstash是开源的服务器端数据处理管道,能够同时从多个来源采集数据,转换数据,然后将数据发送到您最喜欢的“存储库”中。

整体的功能其实是一个管道

  • 一端是存储数据的位置:ES
  • 另外一端是外部,被称为数据源,一般叫DS,是一些数据

    可能是代码、应用等都有可能

logStash中被分为三段:

  • 最左侧是input:相当于创建了一个服务器

    当前logStash安装在某一个ip地址,input监听一个端口port;外部系统将要存储的数据通过ip和port编译进来

  • 中间的一块叫filter,过滤器功能就是将外部系统输入的数据做一些转换,转为想要输出的结果样式
  • 最右侧是output:这不是一个服务而是一个应用,这是logStash就变为客户端了,它用输出去连接es,像es的某一个索引去写数据

总结:

  1. 外部可以有若干个应用去连接这个port,这个服务器也可以开启若干个端口port,可以有不同的input对应不同的filter,有不同的output
  2. logStash是一个集中处理的单元(一个服务),可以将若干不同的应用的数据收集起来,通过filter做转换,转换完成以后将其结果数据存储到es中

使用Logstash原因

日志:

  1. 分析用户行为;
  2. 分析异常问题:数据的恢复

将这些日志集中管理,并提供集中检索功能,不仅可以提高诊断的效率,同时对系统情况有个全面的理解,避免事后救火的被动。

所以日志集中管理功能就可以使用ELK技术栈进行实现。Elasticsearch只有数据存储和分析的能力,Kibana就是可视化管理平台。还缺少数据收集和整理的角色,这个功能就是Logstash负责的

工作原理

Data Source

Logstash支持的数据源有很多(文本、网络类型、文件类型等)。例如对于日志功能来说只能能有日志记录和日志传递功能的日志都支持,Spring Boot 中默认推荐logback支持日志输出功能(输出到数据库、数据出到文件)。

springoot如下所示,其输出的就是logback日志
在这里插入图片描述

我们就使用logback进行日志输出给Logstash。

对于Logstash来说,Data Source不是数据库DB,而是数据的来源

Logstash Pipeline

整个整体就是 Logstash的功能。
一个logstash中可以启动多个Logstash Pipeline

在Logstash中包含非常重要的三个功能:

  1. Input

    输入源,一般配置为自己监听的主机及端口。DataSource向指定的ip及端口输出日志,input 输入源监听到数据信息就可以进行收集。

  2. Filter

    过滤功能,对收集到的信息进行过滤(额外处理),也可以省略这个配置(不做处理)这个配置不是必要的

  3. Output

    把收集到的信息发送给谁。在ELK技术栈中都是输出给Elasticsearch,后面数据检索和数据分析的过程就给Elasticsearch 了。

最终效果:通过整体步骤就可以把原来一行日志信息转换为Elasticsearch支持的Document形式(键值对形式)的数据进行存储。

在这里插入图片描述

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

?abc!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值