首页 > 经验记录 > java > 关于SpringBoot下logback日志通过用户名进行切分

关于SpringBoot下logback日志通过用户名进行切分

 

首先得有个MDC概念:

 

MDC(Mapped Diagnostic Context,映射调试上下文)是 log4j 和 logback 提供的一种方便在多线程条件下记录日志的功能。某些应用程序采用多线程的方式来处理多个用户的请求。在一个用户的使用过程中,可能有多个不同的线程来进行处理。典型的例子是 Web 应用服务器。当用户访问某个页面时,应用服务器可能会创建一个新的线程来处理该请求,也可能从线程池中复用已有的线程。在一个用户的会话存续期间,可能有多个线程处理过该用户的请求。这使得比较难以区分不同用户所对应的日志。当需要追踪某个用户在系统中的相关日志记录时,就会变得很麻烦。

一种解决的办法是采用自定义的日志格式,把用户的信息采用某种方式编码在日志记录中。这种方式的问题在于要求在每个使用日志记录器的类中,都可以访问到用户相关的信息。这样才可能在记录日志时使用。这样的条件通常是比较难以满足的。MDC 的作用是解决这个问题。

MDC 可以看成是一个与当前线程绑定的哈希表,可以往其中添加键值对。MDC 中包含的内容可以被同一线程中执行的代码所访问。当前线程的子线程会继承其父线程中的 MDC 的内容。当需要记录日志时,只需要从 MDC 中获取所需的信息即可。MDC 的内容则由程序在适当的时候保存进去。对于一个 Web 应用来说,通常是在请求被处理的最开始保存这些数据。

 

在xml按照如下代码进行配置:

discriminator该标签则代表是一个动态的值,默认设置为admin

也是通过指定log文件保存路径时来加入该动态参数,如果有的话则保存在该参数对应的文件夹下按照日期进行保存。

如果没有则会保存在admin目录下

 

然后比较重要的,值从哪儿来??

就是通过MDC这个类。(slf4j包)

在进行日志记录之前,比如logger.info或者logger.error等操作之前

调用MDC.put (key,value)。key则是你在discriminator标签中指定好的参数名,而值就是传过去的参数。

因为每个请求都是一个线程,所以建议在Controller层中请求到的方法第一行就给他加上,这时该线程之后所有进行的日志操作都会保存在你指定好的目录下

 

关于logback配置文件各标签定义可以参考:https://www.jianshu.com/p/f67c721eea1b

           


EA PLAYER &

历史记录 [ 注意:部分数据仅限于当前浏览器 ]清空

      00:00/00:00