All Downloads are FREE. Search and download functionalities are using the official Maven repository.

xsheng.springboot-faster-system.1.1.6.source-code.log4j2-spring.xml Maven / Gradle / Ivy

The newest version!
<?xml version="1.0" encoding="UTF-8"?>
<!--status:Log4j2内部日志的输出级别,WARN等,设置为TRACE对学习Log4j2非常有用 -->
<!--monitorInterval:定时检测配置文件的修改,有变化则自动重新加载配置,时间单位为秒,最小间隔为5s -->
<Configuration status="WARN" monitorInterval="1800">
    <!--properties:设置全局变量 -->
    <Properties>
        <!--LOG_HOME:指定当前日志存放的目录 -->
        <Property name="LOG_HOME">${spring:app.module.log.log4j.home:-./logs}</Property>
        <!--FILE_NAME:指定日志文件的名称 -->
        <Property name="APPLICATION_NAME">${spring:spring.application.name:-admin}-${spring:server.port:-8080}</Property>
        <Property name="FILE_NAME">${spring:app.module.log.log4j.file-prefix:-${APPLICATION_NAME}}</Property>
        <Property name="LOG_EXCEPTION_CONVERSION_WORD">%xwEx</Property>
        <Property name="LOG_LEVEL_PATTERN">%5p</Property>
        <Property name="LOG_DATEFORMAT_PATTERN">yyyy-MM-dd HH:mm:ss.SSS</Property>
        <Property name="CONSOLE_PATTERN">%clr{%d{${LOG_DATEFORMAT_PATTERN}}}{faint} %clr{${sys:LOG_LEVEL_PATTERN}} %clr{%pid}{magenta} %clr{---}{faint} %clr{[%15.15t]}{faint} %clr{%-40.40c{1.}}{cyan} %clr{:}{faint} %m%n${sys:LOG_EXCEPTION_CONVERSION_WORD}</Property>
        <Property name="LOG_PATTERN">%d{${LOG_DATEFORMAT_PATTERN}} %p [%t] %c : %m%n${sys:LOG_EXCEPTION_CONVERSION_WORD}</Property>
        <Property name="FILE_SIZE">${spring:app.module.log.log4j.file-size:-100MB}</Property>
        <Property name="FILE_INDEX_MAX">${spring:app.module.log.log4j.file-index:-10}</Property>
        <Property name="FILE_AGE">${spring:app.module.log.log4j.file-age:-3600D}</Property>
    </Properties>
    <!--Appenders:定义日志输出目的地,内容和格式等 -->
    <Appenders>
        <!--Console:日志输出到控制台标准输出 -->
        <Console name="Console" target="SYSTEM_OUT">
            <!--pattern:日期,线程名,日志级别,日志名称,日志信息,换行 -->
            <PatternLayout pattern="${CONSOLE_PATTERN}" />
        </Console>
        <!--RollingFile:日志输出到文件,下面的文件都使用相对路径 -->
        <!--fileName:当前日志输出的文件名称 -->
        <!--filePattern:备份日志文件名称,备份目录为logs下面以年月命名的目录,备份时使用gz格式压缩 -->
        <RollingFile name="RollingFile" fileName="${LOG_HOME}/${FILE_NAME}.log"
                     filePattern="${LOG_HOME}/$${date:yyyy-MM}/${FILE_NAME}-%d{yyyy-MM-dd}-%i.log">
            <PatternLayout pattern="${LOG_PATTERN}" />
            <!--Policies:触发策略决定何时执行备份 -->
            <Policies>
                <!--TimeBasedTriggeringPolicy:日志文件按照时间备份 -->
                <!--interval:每1天生成一个新文件,时间单位需要结合filePattern时间%d{yyyy-MM-dd} -->
                <!--同理,如果要每1小时生成一个新文件,则改成%d{yyyy-MM-ddHH} -->
                <!--modulate:对备份日志的生成时间纠偏,纠偏以0为基准进行,"0+interval"决定启动后第一次备份时间 -->
                <TimeBasedTriggeringPolicy interval="1" modulate="true" />
                <!--SizeBasedTriggeringPolicy:日志文件按照大小备份 -->
                <!--size:指定日志文件最大为100MB,单位可以为KB、MB或GB -->
                <SizeBasedTriggeringPolicy size="${FILE_SIZE}" />
            </Policies>
            <!--DefaultRolloverStrategy:翻转策略决定如何执行备份 -->
            <!--max:最多保存N个备份文件,结合时间使用后,在每个时间段内最多有N个备份,多出来的会被覆盖info-1.log,info-2.log,...,info-N.log -->
            <!--compressionLevel:配置日志压缩级别,范围0-9,0不压缩,1压缩速度最快,9压缩率最好,目前只对于zip压缩文件类型有效 -->
            <DefaultRolloverStrategy max="${FILE_INDEX_MAX}" compressionLevel="1">
                <!--Delete:删除匹配到的过期备份文件 -->
                <!--maxDepth:由于备份文件保存在${LOG_HOME}/$${date:yyyy-MM},所以目录深度设置为2 -->
                <Delete basePath="${LOG_HOME}" maxDepth="2">
                    <!--IfFileName:匹配文件名称 -->
                    <!--glob:匹配2级目录深度下的以.log.gz结尾的备份文件 -->
                    <IfFileName glob="*/${FILE_NAME}-*.log" />
                    <!--IfLastModified:匹配文件修改时间 -->
                    <!--age:匹配超过180天的文件,单位D、H、M、S分别表示天、小时、分钟、秒-->
                    <IfLastModified age="${FILE_AGE}" />
                </Delete>
            </DefaultRolloverStrategy>
        </RollingFile>
    </Appenders>
    <!--Loggers:定义日志级别和使用的Appenders -->
    <Loggers>

        <SpringProfile name="dev">
            <!--name: 打印日志的类的包路径 -->
            <!--additivity: true当前的Logger打印的日志附加到Root,false仅仅打印到RollingFile -->
            <Logger name="com.github.rexsheng.springboot.faster" level="info">
            </Logger>
            <Logger name="mybatis-flex-sql" level="info" additivity="true">
            </Logger>
        </SpringProfile>
        <Logger name="org.apache.flink" level="warn">
        </Logger>
        <Logger name="com.ververica.cdc.connectors.mysql" level="warn" additivity="true">
        </Logger>
        <Logger name="io.debezium" level="warn" additivity="true">
        </Logger>
        <Logger name="com.github.shyiko.mysql" level="warn" additivity="true">
        </Logger>
        <Logger name="org.springframework.security" level="info" additivity="true">
        </Logger>
        <!--Root:日志默认打印到控制台 -->
        <!--level日志级别: ALL < TRACE < DEBUG < INFO < WARN < ERROR < FATAL < OFF -->
        <Root level="INFO">
            <AppenderRef ref="Console" />
            <SpringProfile name="!dev &amp; !default">
                <AppenderRef ref="RollingFile" />
            </SpringProfile>
        </Root>
    </Loggers>
</Configuration>




© 2015 - 2024 Weber Informatics LLC | Privacy Policy