【Java】全网最详细的logback日志配置说明(用于生产环境日志存储)

前言

  我们搭建项目中一般都需要对日志进行管理,一般有log4j和logback两个日志框架,而logback性能较好,是我们的首选,本编整理了详细的logback日志配置,包括日志压缩存储,按天存储,按照日志大小切割日志文件等等置,大家可以直接复制并根据自己的项目情况配置相关参数用于生产环境,具体如下:

<?xml version="1.0" encoding="UTF-8"?>
<!--logback有5种级别,分别是TRACE < DEBUG < INFO < WARN < ERROR,定义于ch.qos.logback.classic.Level类中。-->
<!--scan : 当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true-->
<!--scanPeriod : 设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性生效。默认的时间间隔为1分钟。-->
<!--debug : 当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。-->
<configuration scan="true" scanPeriod="60 seconds" debug="false">
    <!--设置存储路径变量-->
    <property name="LOG_HOME" value="./logs"/>
    <!--项目名称-->
    <property name="APP_NAME" value="technology-learning"/>
    <!--日志级别,此处配置级别会被配置文件中覆盖,如果配置文件不配置默认走此处级别-->
    <property name="log.level" value="info"/>
    <!-- 日志最大的历史(单位:天 )不配置视为永久保存-->
    <property name="log.maxHistory" value="2"/>
    <!--日志切割最大大小-->
    <property name="log.maxSize" value="100MB" />
    <!--格式化输出-->
    <property name="log.pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n"/>
    <!--控制台输出appender-->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <!--设置输出格式-->
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
            <!--设置编码-->
            <charset>UTF-8</charset>
        </encoder>
    </appender>
    <!--以下两个示例,分为时间窗口切割、时间窗口+大小切割两种模式-->
    <!--一、时间窗口切割,全级别输出-->
    <!--    <appender name="timeFileOutput" class="ch.qos.logback.core.rolling.RollingFileAppender">-->
    <!--        &lt;!&ndash;日志名,指定最新的文件名,其他文件名使用FileNamePattern &ndash;&gt;-->
    <!--        <File>${LOG_HOME}/log/${APP_NAME}.log</File>-->
    <!--        &lt;!&ndash;文件滚动模式&ndash;&gt;-->
    <!--        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">-->
    <!--            &lt;!&ndash;日志文件输出的文件名,可设置文件类型为gz,开启文件压缩&ndash;&gt;-->
    <!--            <FileNamePattern>${LOG_HOME}/log/${APP_NAME}-%d{yyyy-MM-dd}.%i.log.gz</FileNamePattern>-->
    <!--            &lt;!&ndash;日志文件保留天数&ndash;&gt;-->
    <!--            <maxHistory>${log.maxHistory}</maxHistory>-->
    <!--        </rollingPolicy>-->
    <!--        &lt;!&ndash;输出格式&ndash;&gt;-->
    <!--        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">-->
    <!--            &lt;!&ndash;格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符&ndash;&gt;-->
    <!--            <pattern>${log.pattern}</pattern>-->
    <!--            &lt;!&ndash;设置编码&ndash;&gt;-->
    <!--            <charset>UTF-8</charset>-->
    <!--        </encoder>-->
    <!--    </appender>-->
    <!--一、时间窗口+大小切割,全级别输出-->
    <!--    <appender name="timeAndSizeFileOutput" class="ch.qos.logback.core.rolling.RollingFileAppender">-->
    <!--        &lt;!&ndash;日志名,指定最新的文件名,其他文件名使用FileNamePattern &ndash;&gt;-->
    <!--        <File>${LOG_HOME}/log/${APP_NAME}.log</File>-->
    <!--        &lt;!&ndash;文件滚动模式&ndash;&gt;-->
    <!--        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">-->
    <!--            &lt;!&ndash;日志文件输出的文件名,可设置文件类型为gz,开启文件压缩&ndash;&gt;-->
    <!--            <FileNamePattern>${LOG_HOME}/log/${APP_NAME}-%d{yyyy-MM-dd}.%i.log.gz</FileNamePattern>-->
    <!--            &lt;!&ndash;日志文件保留天数&ndash;&gt;-->
    <!--            <maxHistory>${log.maxHistory}</maxHistory>-->
    <!--            &lt;!&ndash;默认值10M,当文件大小超过log.maxSize时,通知RollingPolicy轮转&ndash;&gt;-->
    <!--            <maxFileSize>${log.maxSize}</maxFileSize>-->
    <!--        </rollingPolicy>-->
    <!--        &lt;!&ndash;输出格式&ndash;&gt;-->
    <!--        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">-->
    <!--            &lt;!&ndash;格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符&ndash;&gt;-->
    <!--            <pattern>${log.pattern}</pattern>-->
    <!--            &lt;!&ndash;设置编码&ndash;&gt;-->
    <!--            <charset>UTF-8</charset>-->
    <!--        </encoder>-->
    <!--    </appender>-->
    <!--info日志-->
    <appender name="infofile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!-- 指定日志文件的名称 -->
        <file>${LOG_HOME}/infolog/${APP_NAME}-info.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!--日志文件输出的文件名,可设置文件类型为gz,开启文件压缩-->
            <fileNamePattern>${LOG_HOME}/infolog/${APP_NAME}-%d{yyyy-MM-dd}-%i.log.gz</fileNamePattern>
            <!--日志文件保留天数-->
            <maxHistory>${log.maxHistory}</maxHistory>
            <!--默认值10M,当文件大小超过log.maxSize时,通知RollingPolicy轮转-->
            <maxFileSize>${log.maxSize}</maxFileSize>
        </rollingPolicy>
        <encoder>
            <pattern>${log.pattern}</pattern>
        </encoder>
        <!-- 过滤器,过滤掉不是指定日志水平的日志 -->
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <!-- 设置日志级别 -->
            <level>info</level>
            <!-- 如果跟该日志水平相匹配,则接受 -->
            <onMatch>ACCEPT</onMatch>
            <!-- 如果跟该日志水平不匹配,则过滤掉 -->
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>
    <!--debug日志-->
    <appender name="debugfile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!-- 指定日志文件的名称 -->
        <file>${LOG_HOME}/debuglog/${APP_NAME}-debug.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!--日志文件输出的文件名,可设置文件类型为gz,开启文件压缩-->
            <fileNamePattern>${LOG_HOME}/debuglog/${APP_NAME}-%d{yyyy-MM-dd}-%i.log.gz</fileNamePattern>
            <!--日志文件保留天数-->
            <!--            <maxHistory>${log.maxHistory}</maxHistory>-->
            <!--默认值10M,当文件大小超过log.maxSize时,通知RollingPolicy轮转-->
            <maxFileSize>${log.maxSize}</maxFileSize>
        </rollingPolicy>
        <encoder>
            <pattern>${log.pattern}</pattern>
        </encoder>
        <!-- 过滤器,过滤掉不是指定日志水平的日志 -->
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <!-- 设置日志级别 -->
            <level>debug</level>
            <!-- 如果跟该日志水平相匹配,则接受 -->
            <onMatch>ACCEPT</onMatch>
            <!-- 如果跟该日志水平不匹配,则过滤掉 -->
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>
    <!--error日志-->
    <appender name="errorfile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!-- 指定日志文件的名称 -->
        <file>${LOG_HOME}/errorlog/${APP_NAME}-error.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!--日志文件输出的文件名,可设置文件类型为gz,开启文件压缩-->
            <fileNamePattern>${LOG_HOME}/errorlog/${APP_NAME}-%d{yyyy-MM-dd}-%i.log.gz</fileNamePattern>
            <!--日志文件保留天数-->
            <!--            <maxHistory>${log.maxHistory}</maxHistory>-->
            <!--默认值10M,当文件大小超过log.maxSize时,通知RollingPolicy轮转-->
            <maxFileSize>${log.maxSize}</maxFileSize>
        </rollingPolicy>
        <encoder>
            <pattern>${log.pattern}</pattern>
        </encoder>
        <!-- 过滤器,过滤掉不是指定日志水平的日志 -->
        <filter class="ch.qos.logback.classic.filter.LevelFilter">
            <!-- 设置日志级别 -->
            <level>error</level>
            <!-- 如果跟该日志水平相匹配,则接受 -->
            <onMatch>ACCEPT</onMatch>
            <!-- 如果跟该日志水平不匹配,则过滤掉 -->
            <onMismatch>DENY</onMismatch>
        </filter>
    </appender>

    <!--指定基础的日志输出级别-->
    <root>
        <level value="${log.level}"/>
        <!--appender将会添加到这个loger-->
        <appender-ref ref="console"/>
        <appender-ref ref="errorfile"/>
        <appender-ref ref="infofile"/>
        <appender-ref ref="debugfile"/>
    </root>
</configuration>

完结撒花,欢迎订阅专栏!

  • 16
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Java 中使用 Logback 日志记录器并实现日志按天分类压缩保存,你需要进行以下步骤: 1. 在项目中添加 logback 相关依赖,例如: ```xml <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>${logback.version}</version> </dependency> ``` 2. 创建 logback.xml 配置文件,并配置日志记录器。以下是一个基本的配置示例: ```xml <configuration> <appender name="console" class="ch.qos.logback.core.ConsoleAppender"> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> </appender> <appender name="dailyRollingFileAppender" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>logs/myapp.log</file> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <fileNamePattern>logs/myapp.%d{yyyy-MM-dd}.log.gz</fileNamePattern> <maxHistory>30</maxHistory> </rollingPolicy> <encoder> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> </appender> <root level="info"> <appender-ref ref="console" /> <appender-ref ref="dailyRollingFileAppender" /> </root> </configuration> ``` 3. 在 Java 代码中使用 Logback 记录日志。例如: ```java import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class MyClass { private static final Logger logger = LoggerFactory.getLogger(MyClass.class); public void doSomething() { logger.info("This is an info message."); logger.error("This is an error message.", new Exception("Something went wrong.")); } } ``` 以上配置将创建一个名为 `dailyRollingFileAppender` 的日志记录器,它将每天生成一个新的日志文件。日志文件名格式为 `logs/myapp.<yyyy-MM-dd>.log.gz`,并在超过 30 天的日志文件后自动删除旧日志日志文件将以 gzip 格式压缩保存。同时,在控制台输出日志信息。可以根据需要调整这些配置项。 希望这些信息能对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值