springboot + elk第四篇:springboot整合elk

1.搭建springboot工程,应该没人不会搭吧,此步骤省略

2.添加相关依赖,我用的gradle

//变量配置,用来定义版本号
ext {
    set('springBootVersion', "2.3.2.RELEASE")
    set('lombokVersion', "1.18.12")
    set('logstashVersion', "6.6")
}

dependencies {
    // logstash日志收集
    implementation group: 'net.logstash.logback', name: 'logstash-logback-encoder', version: "${logstashVersion}"
    //web依赖
    compile 'org.springframework.boot:spring-boot-starter-web'
    //除了用来生成getter,setter,还用来使用@Slf4j注解
    compile "org.projectlombok:lombok:${lombokVersion}"
    annotationProcessor "org.projectlombok:lombok:${lombokVersion}"
}

spring-boot-starter-web依赖说明:
主要是因为web依赖中包含 spring-boot-starter-logging
项目中正好需要使用web,就只导了web,如果不需要web依赖,则需要导入spring-boot-starter-logging

3.项目resourses目录下添加logback.xml配置文件,配置内容如下,注意修改logstash地址



    
    
    
    
    
    
        
            INFO
        
        false
        
            
            
            %d{yyyy-MM-dd HH:mm:ss} %highlight(%-5level) -- %boldMagenta([%thread]) %boldCyan(%logger) : %msg%n
            UTF-8
        
    

    
    
    
        192.168.81.120:5043
        
        
            
            {"applicationName":"${applicationName}"}
        
    

    
    
        
            
            ${LOG_HOME}/TestWeb.log.%d{yyyy-MM-dd}.log
            
            30
        
        
            
            %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
        
        
        
            10MB
        
    

    
    
        
        
    

xml的关键在于logstash的appender,和root节点使用哪一个appender





  
  ${logstashSrvAddr}
  
  
    
    {"applicationName":"${applicationName}"}
  


4.关键配置信息已经全部配置完成,接下来编写一个controller测试一下

import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @author Torture
 * @description 测试elk
 */
@RestController
@Slf4j
public class LogController {

    @GetMapping("/log")
    public void log(){
        //使用lombok的@Slf4j注解之后,可以直接使用下面方式直接打印日志,无须使用工厂获得logger对象
        log.info("springboot + elk 日志测试......");
    }
}

5.启动springboot

启动springboot2.png

6.配置一下kibana的索引模式

配置过程:


kibana创建索引模式1.png
kibana创建索引模式2.png
kibana创建索引模式3.png

7.使用postman进行日志测试

info日志请求.png

idea控制台输出结果:


idea控制台输出info日志.png

在kibana中我们可以发现,日志已经成功展示出来了!


logstash查看日志列表.png

下面我们再测试一下error日志下,logstash是怎么展示的!

测试类:

import com.zxj.qdzc.common.ServiceException;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @author Torture
 * @description 测试elk
 */
@RestController
@Slf4j
public class LogController {

    @GetMapping("/errorLog")
    public void log(){
        Exception e = new ServiceException("springboot + elk 错误日志测试......");
        log.error(e.getMessage(),e);
    }
}

使用postman请求error日志:


请求error日志.png

idea控制台输出结果:


idea控制台error日志输出.png

kibana展示error日志:


logstash error日志展示.png

展开详情看看,发现连错误日志的堆栈信息都打印出来了,妙啊!


logstash error日志详情.png

8.最后我们再来使用kibana筛选一下日志级别

点击添加筛选按钮:


logstash日志条件筛选.png

我们来筛选一下error日志:


logstash日志条件筛选2.png

筛选结果:


logstash日志筛选结果展示.png

至此,springboot 整合 elk的教程完结撒花!

转载请说明出处!
上一篇:springboot + elk第三篇:docker部署logstash

你可能感兴趣的:(springboot + elk第四篇:springboot整合elk)