千家信息网

如何使用logback自定义deviceId,并根据deviceId生成各自的日志文件

发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,这篇文章主要介绍"如何使用logback自定义deviceId,并根据deviceId生成各自的日志文件",在日常操作中,相信很多人在如何使用logback自定义deviceId,并根据deviceI
千家信息网最后更新 2025年01月19日如何使用logback自定义deviceId,并根据deviceId生成各自的日志文件

这篇文章主要介绍"如何使用logback自定义deviceId,并根据deviceId生成各自的日志文件",在日常操作中,相信很多人在如何使用logback自定义deviceId,并根据deviceId生成各自的日志文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"如何使用logback自定义deviceId,并根据deviceId生成各自的日志文件"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

1.层级目录截图

2.pom依赖,注意--idea下载lombok插件

   org.projectlombok   lombok   1.16.16   org.slf4j   slf4j-api   1.7.25

3.logback文件

                        %d{HH:mm:ss.SSS} [%thread] %level %logger{35} - %msg%n                                            deviceId            unknown                                                        true                                    [%d{yyyy-MM-dd HH:mm:ss.SSS}] %-5level %logger{35} - %msg%n                                                                        D:/mylogs/%d{yyyyMMdd}/deviceId-${deviceId}-%i.log                    500MB                    60                    20GB                                                    INFO                                                                

4.测试类

import org.apache.log4j.MDC;import org.slf4j.Logger;import org.slf4j.LoggerFactory;public class TestLogback {public static final Logger logger = LoggerFactory.getLogger(TestLogback.class);    public void test1(){        MDC.put("deviceId", "deviceId3");        logger.debug("deviceId3 connected");        MDC.put("deviceId", "deviceId4");        logger.error("deviceId4   ---connected");        MDC.put("deviceId", "deviceId5");        logger.info("deviceId5   ---connected");    }public void test2(){        MDC.put("deviceId", "deviceId2");        logger.trace("deviceId2 connected");    }public static void main(String[] args) {final TestLogback testLogback = new TestLogback();        testLogback.test1();        testLogback.test2();    }}

5.效果截图

注意点:用log打印日志前需要拿到该设备的唯一标识。重点在于 :

MDC.put("deviceId", "deviceId3");   //根据deviceId3 生成日志文件,有则追加数据,没有则创建该文件。   deviceId3就是打印的唯一标识
logger.debug("deviceId3 connected");     // MDC.put("deviceId", "deviceId3"); 为第一步,  logger.debug("deviceId3 connected"); 打印日志为第二bu

到此,关于"如何使用logback自定义deviceId,并根据deviceId生成各自的日志文件"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

0