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地址

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="false">
    <!--获取springboot的yml配置信息-->
    <springProperty scope="context" name="applicationName" source="spring.application.name" defaultValue="default"/>
    <!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->
    <property name="LOG_HOME" value="/home"/>
    <!--输出到控制台-->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>INFO</level>
        </filter>
        <withJansi>false</withJansi>
        <encoder>
            <!--<pattern>%d %p (%file:%line\)- %m%n</pattern>-->
            <!--格式化输出:%d:表示日期    %thread:表示线程名     %-5level:级别从左显示5个字符宽度  %msg:日志消息    %n:是换行符-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss} %highlight(%-5level) -- %boldMagenta([%thread]) %boldCyan(%logger) : %msg%n</pattern>
            <charset>UTF-8</charset>
        </encoder>
    </appender>

    <!--  日志发送至logstash  -->
    <appender name="logstash" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
    <!-- logstash的服务器地址和通信端口 -->
        <destination>192.168.81.120:5043</destination>
        <!-- encoder is required -->
        <encoder class="net.logstash.logback.encoder.LogstashEncoder">
            <!-- 在elasticsearch的index中追加applicationName字段  -->
            <customFields>{"applicationName":"${applicationName}"}</customFields>
        </encoder>
    </appender>

    <!-- 按照每天生成日志文件 -->
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!--日志文件输出的文件名-->
            <FileNamePattern>${LOG_HOME}/TestWeb.log.%d{yyyy-MM-dd}.log</FileNamePattern>
            <!--日志文件保留天数-->
            <MaxHistory>30</MaxHistory>
        </rollingPolicy>
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
        </encoder>
        <!--日志文件最大的大小-->
        <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
            <MaxFileSize>10MB</MaxFileSize>
        </triggeringPolicy>
    </appender>

    <!-- 日志输出级别 -->
    <root level="INFO">
        <appender-ref ref="logstash"/>
        <appender-ref ref="console"/>
    </root>
</configuration>

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

<!-- 如果需要使用application.yml配置logstash的服务器地址,则使用如下方式配置 -->
<springProperty scope="context" name="logstashSrvAddr" source="logstash.server.addr" defaultValue="default"/>

<appender name="logstash" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
  <!-- logstash的服务器地址和通信端口 -->
  <destination>${logstashSrvAddr}</destination>
  <!-- encoder is required -->
  <encoder class="net.logstash.logback.encoder.LogstashEncoder">
    <!-- 在elasticsearch的index中追加applicationName字段  -->
    <customFields>{"applicationName":"${applicationName}"}</customFields>
  </encoder>
</appender>

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容