美文网首页JAVA进阶
log4j2定期生成和删除过期日志文件的配置

log4j2定期生成和删除过期日志文件的配置

作者: Nisus_Liu | 来源:发表于2018-08-30 16:43 被阅读0次

    如果你做过类似的资料搜索工作, 你会容易找到相关的配置方法. 然而, 但是, 大部分都是你抄我, 我抄你的, 并没有仔细检测, 就写的教程.
    其中重要的就是删除过期日志文件的配置. 很多都说通过max=数字控制.
    这是扯淡, 这个只是控制某时间段内(根据配置不同)文件的数目.
    它并不会关心你的目录下一共有多少个日志文件了. 可想而知, 这样随着时间的推移, 虽然每个时间区间内日志数目控制在范围内, 但是, 总日志文件个数, 依然日益膨胀.

    log4j2.xml

    <?xml version="1.0" encoding="UTF-8"?>
    
    <Configuration status="WARN" monitorInterval="300">   <!-- debug="true" xmlns:log4j="http://jakarta.apache.org/log4j/"-->
        <properties>
            <property name="LOG_HOME">logs/kg</property>
            <property name="FILE_NAME">kg</property>
        </properties>
        <Appenders>
            <Console name="Console" target="SYSTEM_OUT">
                <PatternLayout pattern="[%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %class{36}:%M(%L)] - %msg%xEx%n"/>
            </Console>
            <RollingRandomAccessFile name="MyFile"
                                     fileName="${LOG_HOME}/${FILE_NAME}.log"
                                     filePattern="${LOG_HOME}/$${date:yyyy-MM}/${FILE_NAME}-%d{yyyy-MM-dd-HH}-%i.log">
                <PatternLayout
                        pattern="[%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %class{36}:%M(%L)] - %msg%xEx%n"/>
                <Policies>
                    <TimeBasedTriggeringPolicy interval="1"/>      <!--每1小时/分/... 生成一个文件, 时间依据filePattern的配置-->
                    <SizeBasedTriggeringPolicy size="5 MB"/>
                </Policies>
                <DefaultRolloverStrategy max="30">
                    <Delete basePath="${LOG_HOME}/$${date:yyyy-MM}/" maxDepth="2">
                        <IfFileName glob="*.log" />
                        <!--!Note: 这里的age必须和filePattern协调, 后者是精确到HH, 这里就要写成xH, xd就不起作用
                        另外, 数字最好>2, 否则可能造成删除的时候, 最近的文件还处于被占用状态,导致删除不成功!-->
                        <!--7天-->
                        <IfLastModified age="168H" />
                    </Delete>
                </DefaultRolloverStrategy>
            </RollingRandomAccessFile>
        </Appenders>
    
        <Loggers>
            <!--过滤掉spring和mybatis的一些无用的DEBUG信息-->
            <logger name="org.springframework" level="INFO"/>
            <logger name="org.mybatis" level="INFO"/>
            <Logger name="mylog" level="debug" additivity="false">
                <AppenderRef ref="MyFile"/>
                <AppenderRef ref="Console"/>
            </Logger>
            <Root level="debug">
                <AppenderRef ref="MyFile"/>
                <AppenderRef ref="Console"/>
            </Root>
        </Loggers>
    
    </Configuration>
    
    

    注意:

    • filePattern定义的日志文件后缀精确的时间决定了定期生成日志文件. 精确到dd, 即%d{yyyy-MM-dd}, 则会每天生成一个文件, 精确到HH, 则会每时生成一个文件, ...
    • Delete标签内决定了删除过期文件的规则. 需要注意这里的IfLastModified .age要和filePattern精确的时间一致, 否则貌似无效.
      我这里日志文件会按日期放入子文件夹内, 所以要想统计总数, 需要递归统计, 故设置maxDepth=2.

    依赖jar包

    我这里的依赖可以实现, 将sfl4j类的日志委托给log4j2实现. 所以项目中可以同时使用sfl4jlog4j类的日志系统.

       <properties>
            <log4j2.version>2.8</log4j2.version>
      </properties>
    
    
      <dependency>
                <groupId>commons-logging</groupId>
                <artifactId>commons-logging</artifactId>
            </dependency>
            <!--log4j2-->
            <dependency>
                <groupId>org.apache.logging.log4j</groupId>
                <artifactId>log4j-api</artifactId>
                <version>${log4j2.version}</version>
            </dependency>
            <dependency>
                <groupId>org.apache.logging.log4j</groupId>
                <artifactId>log4j-core</artifactId>
                <version>${log4j2.version}</version>
            </dependency>
            <dependency>
                <groupId>org.apache.logging.log4j</groupId>
                <artifactId>log4j-web</artifactId>
                <version>${log4j2.version}</version>
            </dependency>
            <!--用于与sfl4j保持桥接-->
            <dependency>
                <groupId>org.apache.logging.log4j</groupId>
                <artifactId>log4j-slf4j-impl</artifactId>
                <version>${log4j2.version}</version>
            </dependency>
            <!--//log4j2-->
    

    相关文章

      网友评论

        本文标题:log4j2定期生成和删除过期日志文件的配置

        本文链接:https://www.haomeiwen.com/subject/wrldwftx.html