使用mdcjava创建高质量Java项目

一、快速了解mdcjava

mdcjava 是一个基于spring boot的快速开发代码库。在构建高质量Java Web应用和RESTful Web服务时,在Spring上下文环境中轻松实现良好的应用日志记录,提供简单而强大的MDC功能。

在开发web应用程序时,我们通常需要为用户打印一些错误日志。但是在生产环境中,多个线程并发运行的情况下,错误可能是异步的,并且需要日志中记录相关的Userid或Sessionid等等内容。

对于日志记录来说,这非常重要,因为我们需要了解在特定的时间点,哪些用户遇到了哪些问题。这个问题可以通过MDC(Mapped Diagnostic Contexts) 来解决。

二、MDC的使用

mdcjava 提供了一种简单而有效的方式将相关信息在同一线程中传递,保证在日志中记录MDC的值。首先,我们需要在应用程序中定义一个MDC的key。MDC中的每个键都被映射为特定的值。

接下来,使用下列语句,可以在MDC中存储一个具有特定值的键:

org.slf4j.MDC.put("mykey", "myvalue");

如果您想确保删除键,则可以使用MDC。remove函数,它将键从MDC中删除:

org.slf4j.MDC.remove("mykey");

三、在 Spring Boot 中集成 MDCJava

集成MDCjava 的过程非常简单,只需要在 pom.xml 中添加依赖项。

<dependency>
    <groupId>com.github.dtroupe18</groupId>
    <artifactId>mdcjava-starter</artifactId>
    <version>1.0.0</version>
</dependency>

四、使用 MDCjava 在 web 应用程序中记录日志

下面的示例介绍了在Web应用程序中使用MDC记录日志的方法。

在应用程序中定义MDC的key :

public enum MDCKey{
    USER_ID
}

在Spring Boot应用程序中添加配置类:

@Configuration
public class MDCConfig {

    @Bean
    public MdcInjectionFilter logbackMdcInsertingServletFilter() {
        MdcInjectionFilter filter = new MdcInjectionFilter();
        filter.setMdcKeyPattern(MDCKey.USER_ID.name());
        return filter;
    }

    @Bean
    public FilterRegistrationBean servletRegistrationBean() {
        FilterRegistrationBean registrationBean = new FilterRegistrationBean();
        //构造 filter
        registrationBean.setFilter(logbackMdcInsertingServletFilter());
        //添加过滤规则
        registrationBean.addUrlPatterns("/*");
        registrationBean.setName("logbackMDCFilter");
        return registrationBean;
    }
}

在代码中记录日志,这将自动在日志中记录MDC值:

Logger logger = LoggerFactory.getLogger(MyClass.class);
MDC.put(MDCKey.USER_ID.name(), "12345");
logger.info("some info message");
MDC.remove(MDCKey.USER_ID.name());

五、使用 MDCJava 和Spring AOP实现统一拦截处理

在应用程序的各个方面使用AOP和MDC的一个好处是能够快速且高效地记录应用程序性能日志,甚至可以在运行时确定应用程序的瓶颈。

在这里,我们使用了 @around注释来自定义一个运行器,每当方法被调用时,会首先记录MDC中的相关信息,然后执行目标方法,最后清除日志记录器上的MDC。

@Aspect
@Component
public class LoggingAspect {

  @Around("execution(* com.example..*Controller.*(..))")
  public Object logAroundControllerMethods(ProceedingJoinPoint joinPoint) throws Throwable {
      String methodName = joinPoint.getSignature().getName();
      String className = joinPoint.getTarget().getClass().getName();
      MDC.put("method", methodName);
      MDC.put("class", className);
      try {
          return joinPoint.proceed();
      } finally {
          MDC.remove("method");
          MDC.remove("class");
      }
  }
}

六、结语

通过使用mdcjava,我们能够轻松记录完整的应用日志,并提供简单而强大的MDC功能。Spring 的AOP机制和MDCJava库帮助我们高效的开发日志接口,进一步增强了我们在开发及维护过程中的效率和代码质量。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/188284.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-28 13:29
下一篇 2024-11-28 13:30

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • 掌握magic-api item.import,为你的项目注入灵魂

    你是否曾经想要导入一个模块,但却不知道如何实现?又或者,你是否在使用magic-api时遇到了无法导入的问题?那么,你来到了正确的地方。在本文中,我们将详细阐述magic-api的…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29
  • VSCode为什么无法运行Java

    解答:VSCode无法运行Java是因为默认情况下,VSCode并没有集成Java运行环境,需要手动添加Java运行环境或安装相关插件才能实现Java代码的编写、调试和运行。 一、…

    编程 2025-04-29
  • Java任务下发回滚系统的设计与实现

    本文将介绍一个Java任务下发回滚系统的设计与实现。该系统可以用于执行复杂的任务,包括可回滚的任务,及时恢复任务失败前的状态。系统使用Java语言进行开发,可以支持多种类型的任务。…

    编程 2025-04-29

发表回复

登录后才能评论