使用logback记录日志

  1. Pom引用依赖

<dependency>

<groupId>ch.qos.logback</groupId>

<artifactId>++++logback++++ -classic</artifactId>

<version>1.2.11</version>

</dependency>

  1. logback.xml
XML 复制代码
<?xml version="1.0" encoding="UTF-8"?>

<configuration scan="true" scanPeriod="30 seconds">

    <!-- stdout start 所有信息输出到控制台 -->
    <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{50} [line:%line] - %msg%n</pattern>
        </encoder>
    </appender>
    <!-- stdout end -->
    <appender name="debug-rolling" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <Encoding>UTF-8</Encoding>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
                <!-- 为方便排查问题暂时不做压缩,目前存在刷数据情况,故单个日志文件先调整为5G -->
                <fileNamePattern>logs/log-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
				<maxHistory>30</maxHistory>
                <totalSizeCap>1MB</totalSizeCap>
                <MaxFileSize>100KB</MaxFileSize>
            </rollingPolicy>
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{50} [line:%line] - %msg%n</pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter"><!-- 只打印INFO日志 -->
            <level>DEBUG</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>ACCEPT</onMismatch>
        </filter>

    </appender>

     <appender name="info-rolling" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <Encoding>UTF-8</Encoding>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
                <!-- 为方便排查问题暂时不做压缩,目前存在刷数据情况,故单个日志文件先调整为5G -->
                <fileNamePattern>logs/log-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
				<maxHistory>30</maxHistory>
                <totalSizeCap>1MB</totalSizeCap>
                <MaxFileSize>100KB</MaxFileSize>
            </rollingPolicy>
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{50} [line:%line] - %msg%n</pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter"><!-- 只打印INFO日志 -->
            <level>INFO</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>ACCEPT</onMismatch>
        </filter>

    </appender>	

    <appender name="error-rolling" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <Encoding>UTF-8</Encoding>
         <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
                <!-- 为方便排查问题暂时不做压缩,目前存在刷数据情况,故单个日志文件先调整为5G -->
                <fileNamePattern>logs/mylog-%d{yyyy-MM-dd}.%i.log</fileNamePattern>
				<maxHistory>30</maxHistory>
                <totalSizeCap>1MB</totalSizeCap>
                <MaxFileSize>100KB</MaxFileSize>
            </rollingPolicy>
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{0} - %msg%n</pattern>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.LevelFilter"><!-- 只打印错误日志 -->
            <level>ERROR</level>
            <onMatch>ACCEPT</onMatch>
            <onMismatch>ACCEPT</onMismatch>
        </filter>
    </appender>

    <!-- <appender name="log-trace-rolling" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <Encoding>UTF-8</Encoding>
        <File>${logPath}/log_trace.log</File>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <FileNamePattern>${logPath}/log_trace.log.%d{yyyy-MM-dd-HH}</FileNamePattern>
            <maxHistory>24</maxHistory>
        </rollingPolicy>
        <encoder>
            <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n</pattern>
        </encoder>
    </appender> -->


    <!-- 针对个别包日志可以进行单独的设置级别,用于过滤 -->
    <!-- <logger name="log-trace" additivity="false" level="INFO">
        <appender-ref ref="log-trace-rolling"/>
    </logger>
    <logger name="org.apache.zookeeper.ZooKeeper" additivity="false" level="ERROR">
        <appender-ref ref="time-rolling"/>
    </logger>
    <logger name="org.apache.zookeeper.ClientCnxn" additivity="false" level="ERROR">
        <appender-ref ref="time-rolling"/>
    </logger> -->

    <root level="DEBUG">
        <appender-ref ref="debug-rolling"/>
        <appender-ref ref="info-rolling"/>
	 <appender-ref ref="error-rolling"/>
        <appender-ref ref="stdout"/>
    </root>

</configuration>

详细可到以下链接下载

https://download.csdn.net/download/liuyuxuan2388/86543481

相关推荐
Jinkxs7 分钟前
Java 架构 02:DDD 领域模型设计实战(限界上下文划分)
java·开发语言·架构
百锦再10 分钟前
国产数据库的平替亮点——关系型数据库架构适配
android·java·前端·数据库·sql·算法·数据库架构
IT199513 分钟前
C++使用“长度前缀法”解决TCP“粘包 / 拆包”问题
服务器·网络·c++·tcp/ip
德迅云安全—珍珍14 分钟前
物理服务器、云服务器、裸金属服务器的区别
运维·服务器
爱笑的眼睛1119 分钟前
文本分类的范式演进:从统计概率到语言模型提示工程
java·人工智能·python·ai
好记忆不如烂笔头abc30 分钟前
超微服务器的ipmi调整风扇运行模式
运维·服务器
周杰伦_Jay31 分钟前
【Go/Python/Java】基础语法+核心特性对比
java·python·golang
sszdlbw33 分钟前
后端springboot框架入门学习--第一篇
java·spring boot·学习
一个响当当的名号36 分钟前
ASP.NET 期末突击
运维·服务器
小鹿学程序36 分钟前
jdk配置完之后java -version还是默认的jdk版本如何更改
java·开发语言·python