zoukankan      html  css  js  c++  java
  • Log4j2的Policy触发策略与Strategy滚动策略配置详解

    转载: https://thinkwon.blog.csdn.net/article/details/101628222

    Policy是用来控制日志文件何时(When)进行滚动的;Strategy是用来控制日志文件如何(How)进行滚动的。

    如果配置的是RollingFile或RollingRandomAccessFile,则必须配置一个Policy。

    Policy触发策略
    SizeBasedTriggeringPolicy
    基于日志文件大小的触发策略。单位有:KB,MB,GB

    <SizeBasedTriggeringPolicy size="10 MB"/>

    CronTriggeringPolicy

    基于Cron表达式的触发策略,很灵活。

    <CronTriggeringPolicy schedule="0/5 * * * * ?" />

    TimeBasedTriggeringPolicy
    基于时间的触发策略。该策略主要是完成周期性的log文件封存工作。有两个参数:

    interval,integer型,指定两次封存动作之间的时间间隔。这个配置需要和filePattern结合使用,filePattern日期格式精确到哪一位,interval也精确到哪一个单位。注意filePattern中配置的文件重命名规则是%d{yyyy-MM-dd HH-mm-ss}-%i,最小的时间粒度是ss,即秒钟。
    TimeBasedTriggeringPolicy默认的size是1,结合起来就是每1秒钟生成一个新文件。如果改成%d{yyyy-MM-dd HH},最小粒度为小时,则每一个小时生成一个文件

    modulate,boolean型,说明是否对封存时间进行调制。若modulate=true, 则封存时间将以0点为边界进行偏移计算。比如,modulate=true,interval=4hours, 那么假设上次封存日志的时间为03:00,则下次封存日志的时间为04:00, 之后的封存时间依次为08:00,12:00,16:00

    简单示例:

    <?xml version="1.0" encoding="UTF-8"?>
    <Configuration>
        <Appenders>
            <RollingRandomAccessFile name="File" fileName="./log/app.log"
                                     filePattern="./log/app-%d{yyyy-MM-dd HH-mm}-%i.log">
                <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss,SSS} [%t] %-5level %logger{0} - %msg%n" charset="UTF-8"/>
                <Policies>
                    <!-- 每 5s 翻滚一次 -->
                    <!--<CronTriggeringPolicy schedule="0/5 * * * * ?"/>-->
                    <!--根据当前filePattern配置,日志文件每3分钟滚动一次-->
                    <TimeBasedTriggeringPolicy interval="3"/>
                    <!--日志文件大于10 MB滚动一次-->
                    <SizeBasedTriggeringPolicy size="10 KB"/>
                </Policies>
                <!--保存日志文件个数-->
                <DefaultRolloverStrategy max="10"/>
            </RollingRandomAccessFile>
        </Appenders>
        <Loggers>
            <Root level="info">
                <AppenderRef ref="File"/>
            </Root>
        </Loggers>
    </Configuration>

    Strategy滚动策略

    1. DefaultRolloverStrategy

      默认滚动策略

      常用参数:max,保存日志文件的最大个数,默认是7,大于此值会删除旧的日志文件。

    1. <!--保存日志文件个数--><DefaultRolloverStrategy max="10"/>
    2. DirectWriteRolloverStrategy

      日志直接写入由文件模式表示的文件。这两个Strategy都是控制如何进行日志滚动的,平时大部分用DefaultRolloverStrategy就可以了。

  • 相关阅读:
    华为云薛浩:媒体业务进入全面云化时代,云原生成为必然选择
    Python 绑定:从 Python 调用 C 或 C++
    不藏了,这些Java反射用法总结都告诉你们
    云图说|华为HiLens云上管理平台 花样管理多种端侧设备
    论文解读丨图神经网络应用于半结构化文档的命名实体识别和关系提取
    动手实操丨基于随机森林算法进行硬盘故障预测
    教你几招HASH表查找的方法
    MindSpore模型精度调优实战:如何更快定位精度问题
    云图说|应用魔方AppCube:揭秘码农防脱神器
    java算法易筋经:常见java-API使用技巧
  • 原文地址:https://www.cnblogs.com/brithToSpring/p/15109090.html
Copyright © 2011-2022 走看看