Springboot集成syslog+logstash收集日志到ES

Springboot集成syslog+logstash收集日志到ES

1、背景

Logstash 是一个实时数据收集引擎,可收集各类型数据并对其进行分析,过滤和归纳。按照自己条件分析过滤出符合的数据,导入到可视化界面。它可以实现多样化的数据源数据全量或增量传输,数据标准格式处理,数据格式化输出等的功能,常用于日志处理。工作流程分为三个阶段:

  1. input数据输入阶段,可接收oracle、mysql、postgresql、file等多种数据源;
  2. filter数据标准格式化阶段,可过滤、格式化数据,如格式化时间、字符串等;
  3. output数据输出阶段,可输出到elasticsearch、mongodb、kafka等接收终端。

架构原理:springboot发出syslog日志,通过系统的rsyslog服务进行数据转发,logstash监听rsyslog端口过滤数据并发到es进行存储

2、springboot集成syslog

maven依赖:

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.7</version>
</dependency>
<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-core</artifactId>
    <version>1.1.7</version>
</dependency>
<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.1.7</version>
</dependency>

logback.xml文件配置

配置好日志之后,在root标签中添加appender才能生效;

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">
  <!-- 控制台输出 -->
  <appender name="consoleLogAppender" class="ch.qos.logback.core.ConsoleAppender">
    <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
      <level>INFO</level>
    </filter>
    <encoder>
      <pattern>%d{
   yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{
   20} - %cyan(%.-3072msg %n)</pattern>
    </encoder>
  </appender>

  <appender name="infoFileAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <File>./logs/service.log</File>
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
      <level>INFO</level>
      <onMatch>ACCEPT</onMatch>
      <onMismatch>DENY</onMismatch>
    </filter>
    <encoder>
      <pattern>%d{
   yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{
   20} - %cyan(%.-3072msg %n)</pattern>
    </encoder>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
      <fileNamePattern>./logs/service-log-%d{
   yyyy-MM-dd}.log</fileNamePattern>
      <maxHistory>15</maxHistory>
      <totalSizeCap>5GB</totalSizeCap>
    </rollingPolicy>
  </appender>
  <appender name="errorFileAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <File>./logs/service-error.log</File>
    <filter class="ch.qos.logback.classic.filter.LevelFilter">
      <level>ERROR</level>
      <onMatch>ACCEPT</onMatch>
      <onMismatch>DENY</onMismatch>
    </filter>
    <encoder>
      <pattern>%d{
   yyyy-MM-dd HH:mm:ss} 
### Spring Cloud与ELK集成教程 将Spring Cloud应用程序的日志数据发送到ELK堆栈(Elasticsearch, Logstash, Kibana),可以实现日志的集中化管理、分析以及可视化。以下是关于如何完成这一目标的技术细节。 #### 配置Logback作为日志框架 Spring Boot默认使用Logback作为其日志记录工具。为了向ELK传输日志,可以通过配置Logback来支持TCP或UDP协议下的Syslog输出模式[^1]。这一步骤的关键在于调整`logback-spring.xml`文件中的设置: ```xml <configuration> <appender name="LOGSTASH" class="net.logstash.logback.appender.LogstashTcpSocketAppender"> <destination>localhost:5000</destination> <encoder class="net.logstash.logback.encoder.LoggingEventCompositeJsonEncoder"> <providers> <timestamp/> <version/> <message/> <loggerName/> <threadName/> <levelValue/> <stackTrace/> </providers> </encoder> </appender> <root level="INFO"> <appender-ref ref="LOGSTASH"/> </root> </configuration> ``` 上述XML片段定义了一个名为`LOGSTASH`的应用程序追加器,它通过TCP连接至运行在本地主机上的Logstash服务端口5000,并采用JSON编码方式传递每条日志事件的信息。 #### 设置Logstash管道处理输入源 为了让Logstash能够接收来自Spring应用的日志消息并将其转发给Elasticsearch存储起来,在Logstash中创建一个新的配置文件用于描述这个流程逻辑如下所示: ```plaintext input { tcp { port => 5000 codec => json } } output { elasticsearch { hosts => ["http://localhost:9200"] index => "spring-app-%{+YYYY.MM.dd}" } } ``` 此脚本指定了一个基于TCP监听于指定端口(这里是5000),并且期望接收到的数据是以JSON格式编码后的标准输入流;随后这些解析出来的结构化字段会被索引进名称带有日期前缀的ES索引里去。 #### 使用Kibana进行数据分析和展示 一旦所有的组件都已正确定位并与彼此通信,则可以在浏览器打开访问地址指向安装好的kibana实例页面来进行进一步探索操作了。比如建立仪表板图表显示错误率趋势图或者查询特定时间段内的请求延迟分布情况等等。 ```python import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 以上代码展示了基本的Spring Boot启动类,实际项目开发过程中还需要考虑更多方面如安全性加固措施等。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值