logbak日志单独打印(方法层级)

logbak日志单独打印

问题

前几天朋友在群里问,怎么针对方法打印打印日志,不是针对类。

解决办法

方法层
java 复制代码
   @GetMapping("getLog1")
    public String getLog1(){

        Logger specialLogger = LoggerFactory.getLogger(TestController.class.getName() + ".getLog1");
        specialLogger.info("Special log message for methodWithSpecialLogging");

        return "success";
    }
logback 配置文件
xml 复制代码
    <logger name="com.test.controller.TestController.getLog1" level="INFO">
        <appender-ref ref="getLog1" />
    </logger>


    <appender name="getLog1" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <fileNamePattern>${LOG_HOME}/%d{yyyy-MM-dd}/getLog.%d{yyyy-MM-dd-HH}.%i.log</fileNamePattern>
            <MaxHistory>10</MaxHistory>
            <maxFileSize>200MB</maxFileSize>
        </rollingPolicy>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss:SSS} %-5level [%X{REQUEST_IP}][%X{TRACE_ID}][%thread][%file:%line] : %msg%n
            </pattern>
        </encoder>
    </appender>

这一步已经做到根据方法打印log日志,但是朋友的具体需求竟然是针对每调用一次方法,生成一个配置文件

直接在方法层实现

每调用一次,输出一份文件

java 复制代码
  @GetMapping("getLog")
    public String getLog(){

        // 创建新的 Logger 实例
        Logger logger = LoggerFactory.getLogger(TestController.class);

        // 获取 Logger 的上下文
        ch.qos.logback.classic.Logger logbackLogger = (ch.qos.logback.classic.Logger) logger;
        ch.qos.logback.classic.LoggerContext loggerContext = logbackLogger.getLoggerContext();

        // 设置该 Logger 实例的 Appender,即日志输出到单独的文件中
        ch.qos.logback.core.FileAppender<ch.qos.logback.classic.spi.ILoggingEvent> fileAppender = new ch.qos.logback.core.FileAppender<>();
        fileAppender.setFile("path/getLog_" + System.currentTimeMillis() + ".log");
        fileAppender.setContext(loggerContext);
        fileAppender.start();

        // 将 Appender 添加到 Logger 实例中
        logbackLogger.addAppender(fileAppender);
        // 设置日志级别
        logbackLogger.setLevel(Level.INFO);

        // 输出日志
        logger.info("Special log message for methodWithSpecialLogging");

        return "success";

    }
相关推荐
月亮不月亮8 分钟前
月亮商场购物打折Java
java·eclipse
guozhetao18 分钟前
【ST表、倍增】P7167 [eJOI 2020] Fountain (Day1)
java·c++·python·算法·leetcode·深度优先·图论
技术思考者18 分钟前
基础很薄弱如何规划考研
java·经验分享·考研
●VON41 分钟前
重生之我在暑假学习微服务第二天《MybatisPlus-下篇》
java·学习·微服务·架构·mybatis-plus
老华带你飞41 分钟前
口腔助手|口腔挂号预约小程序|基于微信小程序的口腔门诊预约系统的设计与实现(源码+数据库+文档)
java·数据库·微信小程序·小程序·论文·毕设·口腔小程序
枫叶丹443 分钟前
【Qt开发】信号与槽(二)-> 信号和槽的使用
开发语言·qt
hqxstudying1 小时前
J2EE模式---服务层模式
java·数据库·后端·spring·oracle·java-ee
GM_8281 小时前
【最新最完整】SpringAI-1.0.0开发MCP Server,搭建MCP Client 实战笔记(进阶+详细+完整代码)
java·后端·ai编程·springai·mcp
都叫我大帅哥1 小时前
Java DelayQueue:时间管理大师的终极武器
java
秋千码途1 小时前
小架构step系列27:Hibernate提供的validator
java·spring·架构·hibernate