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
6.配置一下kibana的索引模式
配置过程:
7.使用postman进行日志测试
idea控制台输出结果:
在kibana中我们可以发现,日志已经成功展示出来了!
下面我们再测试一下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日志:
idea控制台输出结果:
kibana展示error日志:
展开详情看看,发现连错误日志的堆栈信息都打印出来了,妙啊!
8.最后我们再来使用kibana筛选一下日志级别
点击添加筛选按钮:
我们来筛选一下error日志:
筛选结果:
至此,springboot 整合 elk的教程完结撒花!
转载请说明出处!
上一篇:springboot + elk第三篇:docker部署logstash