【问题标题】:Log4j MaxFileSize with DailyRollingFileAppenderLog4j MaxFileSize 与 DailyRollingFileAppender
【发布时间】:2018-03-19 14:29:37
【问题描述】:

我的目标是每天生成日志文件,但MaxFileSize=100KB

所以我使用的是 DailyRollingFileAppender,因为我使用的是 log4j 2.2 版本

日期工作正常,当我使用 MaxFileSize 时它没有工作,并且没有根据文件大小创建新文件,日期仍然有效。

问题:MaxFileSize 不适用于 DailyRollingfileAppender 的 DatePattern

这里是 log4j.properties 文件代码:

log4j.rootLogger=DEBUG, stdout, file

log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

log4j.appender.file=org.apache.log4j.DailyRollingFileAppender  
log4j.appender.file.layout=org.apache.log4j.PatternLayout  
log4j.appender.file.layout.ConversionPattern=%d [%t] %-5p (%F:%L) - %m%n
log4j.appender.file.File=${catalina.home}/logs/abc
log4j.appender.file.MaxFileSize=80KB
log4j.appender.file.MaxBackupIndex=2
log4j.appender.file.DatePattern='-'yyyy-MM-dd'.log'

日期模式需要更改但还不知道

【问题讨论】:

  • 它是否有效?
  • @RomanC 是但不在 maxfilesize 所以你知道我想要这个:filename.date.1, filename.date.2 for the same date if file size is created then next file is created with just simple formatted编号
  • 我认为log4j 2.2 版本没有DailyRollingFileAppender 。看来您正在使用 log4j 版本 1 配置
  • @VikasSachdeva 感谢 vikas 我想通了,但现在我必须重做一遍,因为 log4j 2.x 与 log4j 1.x 不同。能否请您将 log4j 2 的配置发送给 log4j 1.x 的上述相应配置。请将其发布为答案
  • @VikasSachdeva 任务是翻转日期和大小

标签: java log4j log4j2


【解决方案1】:

尝试以下配置以根据时间和大小旋转文件 -

status = warn
name= properties_configuration

property.basePath = ${catalina.home}/logs/

appender.console.type = Console
appender.console.name = consoleLogger
appender.console.target = SYSTEM_OUT
appender.console.layout.type = PatternLayout
appender.console.layout.pattern = %d{yyyy-MM-dd HH:mm:ss} %level %c{1}:%L - %msg%n
appender.rolling.type = RollingFile
appender.rolling.name = fileLogger
appender.rolling.fileName=${basePath}/abc.log
appender.rolling.filePattern=${basePath}abc_%d{yyyyMMdd}-%i.log.gz
appender.rolling.layout.type = PatternLayout
appender.rolling.layout.pattern = %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %level (%F:%L) - %msg%n
appender.rolling.policies.type = Policies
appender.rolling.policies.time.type = TimeBasedTriggeringPolicy
appender.rolling.policies.time.interval = 1
appender.rolling.policies.time.modulate = true
appender.rolling.policies.size.type = SizeBasedTriggeringPolicy
appender.rolling.policies.size.size = 100 KB

# write your package name as the value of this key
logger.example.name = log4j2.example
logger.example.level = info
logger.example.additivity = false
logger.example.appenderRef.rolling.ref = fileLogger
logger.example.appenderRef.console.ref = consoleLogger

rootLogger.level = error
rootLogger.additivity = false
rootLogger.appenderRef.rolling.ref = fileLogger
rootLogger.appenderRef.console.ref = consoleLogger

【讨论】:

  • 我确实做了同样的事情,但它不起作用虽然我知道它是正确的,因为确切的基于 xml 的配置正在工作,请参阅上面关于基于 xml 的配置的答案
【解决方案2】:
   <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE xml>
    <Configuration>
        <Appenders>
            <Console name="Console" target="SYSTEM_OUT">
                <PatternLayout
                    pattern="%d{yyyy-MMM-dd HH:mm:ss a} [%t] %-5level %logger{36} - %msg%n" />
            </Console>

            <!-- Rolling File Appender -->
            <RollingFile name="RollingFile">
                <FileName>C:/logs/x2c.log</FileName>
                <FilePattern>C:/logs/%d{yyyy-MM-dd-hh-mm}-%i.log</FilePattern>
                <PatternLayout>
                    <Pattern>style{%d{yyyy-MMM-dd HH:mm:ss a}}{black} %-5p %style{[%t]}{blue} %highlight{%level}{FATAL=bg_red, ERROR=red, WARN=yellow, INFO=green, DEBUG=blue} %logger{36} - %msg%n</Pattern>
                </PatternLayout>
                <Policies>
                    <TimeBasedTriggeringPolicy interval="2"
                        modulate="true" />
                        <SizeBasedTriggeringPolicy size="80 KB" />
                </Policies>
                <DefaultRolloverStrategy max="5" />
            </RollingFile>

        </Appenders>
        <Loggers>
            <Logger name="com.mkyong.common.controller" level="debug"
                additivity="false">
                <AppenderRef ref="RollingFile" />
                <AppenderRef ref="Console" />
            </Logger>
            <Root level="trace">
                <AppenderRef ref="Console" />
            </Root>
        </Loggers>

    </Configuration>

这是基于 xml 的配置,它工作正常,但确切的属性或基本配置不起作用。文件未创建且没有控制台输出

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-03-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多