关于SpringBoot下logback日志通过用户名进行切分
首先得有个MDC概念:
MDC(Mapped Diagnostic Context,映射调试上下文)是 log4j 和 logback 提供的一种方便在多线程条件下记录日志的功能。某些应用程序采用多线程的方式来处理多个用户的请求。在一个用户的使用过程中,可能有多个不同的线程来进行处理。典型的例子是 Web 应用服务器。当用户访问某个页面时,应用服务器可能会创建一个新的线程来处理该请求,也可能从线程池中复用已有的线程。在一个用户的会话存续期间,可能有多个线程处理过该用户的请求。这使得比较难以区分不同用户所对应的日志。当需要追踪某个用户在系统中的相关日志记录时,就会变得很麻烦。
一种解决的办法是采用自定义的日志格式,把用户的信息采用某种方式编码在日志记录中。这种方式的问题在于要求在每个使用日志记录器的类中,都可以访问到用户相关的信息。这样才可能在记录日志时使用。这样的条件通常是比较难以满足的。MDC 的作用是解决这个问题。
MDC 可以看成是一个与当前线程绑定的哈希表,可以往其中添加键值对。MDC 中包含的内容可以被同一线程中执行的代码所访问。当前线程的子线程会继承其父线程中的 MDC 的内容。当需要记录日志时,只需要从 MDC 中获取所需的信息即可。MDC 的内容则由程序在适当的时候保存进去。对于一个 Web 应用来说,通常是在请求被处理的最开始保存这些数据。
在xml按照如下代码进行配置:
<appender name="file" class="ch.qos.logback.classic.sift.SiftingAppender"> <discriminator> <Key>userNick</Key> <DefaultValue>admin</DefaultValue> </discriminator> <sift> <appender name="FILE-${userNick}" class="ch.qos.logback.core.rolling.RollingFileAppender"> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <fileNamePattern>E:/log-sys/${userNick}/%d{yyyyMMdd}.log</fileNamePattern> <!--<maxFileSize>20MB</maxFileSize>--> </rollingPolicy> <Append>false</Append> <layout class="ch.qos.logback.classic.PatternLayout"> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> </layout> </appender> </sift> </appender>
discriminator该标签则代表是一个动态的值,默认设置为admin
也是通过指定log文件保存路径时来加入该动态参数,如果有的话则保存在该参数对应的文件夹下按照日期进行保存。
如果没有则会保存在admin目录下
然后比较重要的,值从哪儿来??
就是通过MDC这个类。(slf4j包)
在进行日志记录之前,比如logger.info或者logger.error等操作之前
调用MDC.put (key,value)。key则是你在discriminator标签中指定好的参数名,而值就是传过去的参数。
因为每个请求都是一个线程,所以建议在Controller层中请求到的方法第一行就给他加上,这时该线程之后所有进行的日志操作都会保存在你指定好的目录下
关于logback配置文件各标签定义可以参考:https://www.jianshu.com/p/f67c721eea1b