使用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

相关推荐
潘yi.19 分钟前
web技术与nginx网站环境部署
服务器·网络·nginx
安顾里44 分钟前
Linux命令-iostat
linux·运维·服务器
whoarethenext1 小时前
初始https附带c/c++源码使用curl库调用
服务器·c++·qt·https·curl
100编程朱老师1 小时前
面试:什么叫Linux多路复用 ?
linux·运维·服务器
群联云防护小杜1 小时前
云服务器主动防御策略与自动化防护(下)
运维·服务器·分布式·安全·自动化·音视频
Jtti1 小时前
Jtti:nginx服务器如何限制访问频率
服务器·网络·nginx
此木|西贝1 小时前
【设计模式】享元模式
java·设计模式·享元模式
struggle20252 小时前
LinuxAgent开源程序是一款智能运维助手,通过接入 DeepSeek API 实现对 Linux 终端的自然语言控制,帮助用户更高效地进行系统运维工作
linux·运维·服务器·人工智能·自动化·deepseek
李少兄2 小时前
解决Spring Boot多模块自动配置失效问题
java·spring boot·后端