java日志工具类

本文介绍了如何使用Logback对Java应用程序的日志进行分级管理,包括创建不同级别的文件(如info、warn和error),并提供了自定义的日志工具类LogUtils,便于在API调用中方便地记录不同级别的日志。
摘要由CSDN通过智能技术生成

想法

软件运行需要记录日志,然后有的时候公司里的日志就很low,全部都写在的info里面。看着难受。
因此我需要想一下怎么写日志。想法如下:

  1. 日志分级别,info日志写在info日志文件中;warn日志写在warn文件中。
  2. 提供一个日志Util可以直接使用,不需要每次日志还需要new一个对象

logback配置每个日志等级一个文件

<?xml version="1.0" encoding="UTF-8" ?>

<configuration scan="true" scanPeriod="60 seconds" debug="false" packagingData="false">
    <property name="LOG_HOME" value="logs" />

    <appender name="consoleLog" class="ch.qos.logback.core.ConsoleAppender">
        <layout class="ch.qos.logback.classic.PatternLayout">
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level [%X{traceId}] %msg%n</pattern>
        </layout>
    </appender>

    <appender name="request" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!--        <File>${LOG_HOME}/request.%{yyyy-MM-dd}.log</File> 不支持-->
        <File>${LOG_HOME}/request.log</File>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>INFO</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level [%X{traceId}] %msg%n</pattern>
            <!--<charset>UTF-8</charset>-->
        </encoder> <!--滚动策略-->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!--路径-->
            <fileNamePattern>${LOG_HOME}/%d{yyyy-MM-dd_HH-mm,aux}/request.%d{yyyy-MM-dd_HH}.log.gz</fileNamePattern>
            <maxHistory>4</maxHistory>
        </rollingPolicy>
    </appender>

    <!--根据日志级别分离日志,分别输出到不同的文件-->
    <appender name="info" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <File>${LOG_HOME}/info.log</File>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>INFO</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level [%X{traceId}] %msg%n</pattern>
            <!--<charset>UTF-8</charset>-->
        </encoder> <!--滚动策略-->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!--路径-->
            <fileNamePattern>${LOG_HOME}/logs/%d{yyyy-MM-dd,aux}/info.%d{yyyy-MM-dd_HH-mm}.log.gz</fileNamePattern>
            <maxHistory>4</maxHistory>
        </rollingPolicy>
    </appender>

    <appender name="error" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <File>${LOG_HOME}/error.log</File>
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <level>ERROR</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>DENY</onMismatch>
        </filter>
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level [%X{traceId}] %msg%n</pattern>
            <charset>UTF-8</charset>
        </encoder> <!--滚动策略-->
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!--路径-->
            <fileNamePattern>${LOG_HOME}S/%d{yyyy-MM-dd,aux}/error.%d{yyyy-MM-dd_HH}.log.gz</fileNamePattern>
            <maxHistory>4</maxHistory>
        </rollingPolicy>
    </appender>

    <logger name="requestLogger" additivity="false" level="INFO">
        <appender-ref ref="request"/>
    </logger>

    <logger name="infoLogger" additivity="false" level="INFO">
        <appender-ref ref="info"/>
    </logger>

    <logger name="errorLogger" additivity="false" level="ERROR">
        <appender-ref ref="error"/>
    </logger>

    <root level="info">
        <appender-ref ref="consoleLog"/>
    </root>

</configuration>

java日志工具类

需要用到java的堆栈

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class LogUtils {
    private static final Logger infoLogger = LoggerFactory.getLogger("infoLogger");
    private static final Logger requestLogger = LoggerFactory.getLogger("requestLogger");
    private static final Logger errorLogger = LoggerFactory.getLogger("errorLogger");

    public static void info(String msg) {
        StringBuilder builder = getStringBuilder();
        infoLogger.info(builder.append(msg).toString());
    }

    public static void request(String msg) {
        StringBuilder builder = getStringBuilder();
        requestLogger.info(builder.append(msg).toString());
    }

    public static void error(String msg) {
        StringBuilder builder = getStringBuilder();
        errorLogger.error(builder.append(msg).toString());
    }
    
    private static StringBuilder getStringBuilder() {
        StackTraceElement[] stackTraceArr = Thread.currentThread().getStackTrace();
        StackTraceElement stackTrace = stackTraceArr[3];
        String className = stackTrace.getClassName();
        int lineNumber = stackTrace.getLineNumber();
        String methodName = stackTrace.getMethodName();
        StringBuilder builder = new StringBuilder();
        builder.append("[").append(className).append(".").append(methodName).append("] ")
                .append(lineNumber)
                .append(" - ");
        return builder;
    }
}

使用

    @RequestMapping("/log")
    public String log() {
        autoInterface.test();
        for(int i = 0 ; i < 1000; ++i) {
            LogUtils.error("-------error");
            LogUtils.info("-------info");
            LogUtils.request("-------re");
        }
        return "------";
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值