详解Skywalking 采集springboot 应用日志的方法(内附源码)

大家都知道Skywalking 的链路追踪功能非常强大,可以帮助用户深入了解应用程序中各个组件之间的依赖关系。在实际应用中,往往需要将链路追踪数据与日志数据结合起来进行综合分析。Skywalking 提供了 Trace Log 结合插件,可以帮助用户快速定位问题。Skywalking 支持多种日志采集方式,包括 Log4j、SLF4J、Logback 等常见的 Java 日志框架。此外,还支持通过 TCP、UDP、HTTP 等协议传输日志数据。用户可以根据实际需求选择合适的采集方式和传输协议。本文以Skywalking 采集Log4j 2 日志为例,给大家演示完整的日志采集的配置过程。

Skywalking 采集springboot 应用日志

skywalking 版本9.3.0

Pom.xml 配置

复制代码
<dependency>

   <groupId>org.springframework.boot</groupId>

   <artifactId>spring-boot-starter</artifactId>

   <exclusions><!---特别重要 特别重要 特别重要 SpringBoot 默认携带自身的 log 日志功能,去掉默认配置 -->

      <exclusion>

         <groupId>org.springframework.boot</groupId>

         <artifactId>spring-boot-starter-logging</artifactId>

      </exclusion>

   </exclusions>

</dependency>

<dependency> <!-- 引入log4j2依赖 -->

    <groupId>org.springframework.boot</groupId>

    <artifactId>spring-boot-starter-log4j2</artifactId>

</dependency>

<dependency>

      <groupId>org.apache.skywalking</groupId>

      <artifactId>apm-toolkit-log4j-2.x</artifactId>

      <version>9.1.0</version>

</dependency>

        

<dependency>

      <groupId>org.apache.skywalking</groupId>

      <artifactId>apm-toolkit-trace</artifactId>

      <version>9.1.0</version>

 </dependency>

在src\main\resources 根目录下创建文件log4j2.xml

复制代码
<?xml version="1.0" encoding="UTF-8"?>

<Configuration status="INFO">

    <Appenders>

         <!-- 控制台输出 -->

        <Console name="Console" target="SYSTEM_OUT">

            <PatternLayout pattern="%d [%traceId] %-5p %c{1}:%L - %m%n"/>

        </Console>

         <!-- skywalking grpc 日志收集 8.4.0版本开始支持 -->

         <GRPCLogClientAppender name="grpc-log">

            <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>

        </GRPCLogClientAppender>

    </Appenders>

     <Loggers>

        <Root level="INFO">

            <AppenderRef ref="Console"/>

            <AppenderRef ref="grpc-log"/>

        </Root>

    </Loggers>

</Configuration>

在上面的配置文件中

%traceId 代表traceid的值

其他PatternLayout 的常见参数含义如下:

%r : 程序从开始之后跑的时间

%t : 发出日志请求的线程

%-10p : 日志level,"-"号为向左对齐,10为显示的长度

%c : logger的名字,通常就是所在类的全名,后面加上{2}可指定只输出的全名的最后两个

%m : 日志信息

%n : 换行

%d : 日期

%l : 位置

%L: 输出代码中的行号

%X{variableName} : 输出和当前线程相关联的NDC(嵌套诊断环境),{指定变量名输出}

代码中只需要正常使用log4j2的api 写代码即可,

复制代码
import org.apache.skywalking.apm.toolkit.trace.ActiveSpan;

import org.apache.skywalking.apm.toolkit.trace.TraceContext;

import org.slf4j.Logger;

import org.springframework.web.bind.annotation.GetMapping;

import org.springframework.web.bind.annotation.RequestParam;

import org.springframework.web.bind.annotation.RestController;


@RestController

public class HelloWorld {

private static final Logger logger = org.slf4j.LoggerFactory.getLogger(HelloWorld.class );

@GetMapping("/kevin")

public String helloworld(){

   
    logger.info("*****info*****: call helloworld");

    return "Hello World ";


    }



@GetMapping("/kevin/login")

 public String login(@RequestParam(value="name",required=true) String name, @RequestParam(value="password",required=true) String pwd){
        

    logger.info("*****info*****: call login");

    try {

        Thread.sleep(3000);

    } catch (InterruptedException e) {

        // TODO Auto-generated catch block

        e.printStackTrace();

    }


    return name+" "+pwd;


    }

}

完整的工程代码下载地址

https://download.csdn.net/download/liwenxiang629/88799617?spm=1001.2014.3001.5503

skywalking 中的应用日志显示

然后调用几次api 以后,就可以在skywalking的oap 中看到输出的日志信息了

点击上图中的相关日志,显示结果如下:

我的每一篇文章都希望帮助读者解决实际工作中遇到的问题!如果文章帮到了您,劳烦点赞、收藏、转发!您的鼓励是我不断更新文章最大的动力!

相关推荐
李慕婉学姐3 小时前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
QQ5110082853 小时前
python+springboot+django/flask的校园资料分享系统
spring boot·python·django·flask·node.js·php
WeiXin_DZbishe4 小时前
基于django在线音乐数据采集的设计与实现-计算机毕设 附源码 22647
javascript·spring boot·mysql·django·node.js·php·html5
追风筝的人er4 小时前
企业管理系统如何实现自定义首页与千人千面?RuoYi Office 给出了完整方案
vue.js·spring boot·spring cloud
Java水解6 小时前
你真的会打印日志吗?基于 Spring Boot 的全方位日志指南
spring boot·后端
Java水解6 小时前
Spring Boot 实战:MyBatis 操作数据库(上)
spring boot·后端
飞火流星020278 小时前
SkyWalking异步日志采集数据压缩从头到尾实现及踩坑笔记
skywalking·skywalking日志采集·skywalking日志压缩·macos上验证sw日志压缩·sw异步采集日志实现数据压缩
手握风云-12 小时前
JavaEE 进阶第二十期:Spring Boot 中的横切逻辑统一治理方案
java·spring boot·后端
RunsenLIu12 小时前
基于 Spring Boot 3 与 Vue 3 的汽车租赁系统
vue.js·spring boot·汽车