0

I would like to set the log file name for a log4j to have the current date. I needn't to do rollovers and todays log file should be named with a date. As a result I would get a separate log file for each day.

The log file name format would be:

systemName_DDMMYYYY_moduleName.log

David Silva
  • 1,939
  • 7
  • 28
  • 60

1 Answers1

1

2 ways to do I know are :- Use DailyRollingFileAppender ...

<appender name="roll" class="org.apache.log4j.DailyRollingFileAppender">
    <param name="File" value="application.log" />
    <param name="DatePattern" value=".yyyy-MM-dd" />
    <layout class="org.apache.log4j.PatternLayout"> 
      <param name="ConversionPattern" 
          value="%d{yyyy-MMM-dd HH:mm:ss,SSS} [%t] %c %x%n  %-5p %m%n"/>
    </layout>
  </appender>

second,

including apache-log4j-extras

log4j.appender.LOGFILE=org.apache.log4j.rolling.RollingFileAppender
log4j.appender.LOGFILE.RollingPolicy=org.apache.log4j.rolling.TimeBasedRollingPolicy
log4j.appender.LOGFILE.RollingPolicy.FileNamePattern=/logs/application_%d{ddMMyyyy}_moduleName.log
dinesh028
  • 2,137
  • 5
  • 30
  • 47