문제

Log4J 및 Log4Net Appender의 로그 파일 이름을 설정하여 현재 날짜를 설정하고 싶습니다. 우리는 매일 롤오버를하고 있지만 현재 로그 파일에는 날짜가 없습니다. 로그 파일 이름 형식이 될 것입니다

logname.2008-10-10.log

누구든지 내가 이것을하는 가장 좋은 방법을 알고 있습니까?

편집 : Log4net 에서도이 작업을하고 싶다고 언급하는 것을 잊었습니다. 또한 모든 솔루션은 JBoss에서 사용할 수 있어야합니다.

도움이 되었습니까?

해결책

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>

다른 팁

log4j.properties 파일 사용 및 포함 Apache-log4j-extras 1.1 log4J 1.2.16과 함께 내 pom에서

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{yyyy-MM-dd}.log

나는 99% 확신합니다. DatePattern 또한.

당신은 단순히 서브 클래스 RollingFileAppender (또는 dailyrollingfileAppender, log4net에있는 어느 것이 잊어 버리고) 명명 논리를 수정할 수 있습니다.

나는 그렇게 할 애플 렌더를 만들었습니다. http://stauffer.james.googlepages.com/dateformatfileappender.java

/*
 * Copyright (C) The Apache Software Foundation. All rights reserved.
 *
 * This software is published under the terms of the Apache Software
 * License version 1.1, a copy of which has been included with this
 * distribution in the LICENSE.txt file.  */

package sps.log.log4j;

import java.io.IOException;
import java.io.File;
import java.text.SimpleDateFormat;
import java.util.Date;

import org.apache.log4j.*;
import org.apache.log4j.helpers.LogLog;
import org.apache.log4j.spi.LoggingEvent;

/**
 * DateFormatFileAppender is a log4j Appender and extends 
 * {@link FileAppender} so each log is 
 * named based on a date format defined in the File property.
 *
 * Sample File: 'logs/'yyyy/MM-MMM/dd-EEE/HH-mm-ss-S'.log'
 * Makes a file like: logs/2004/04-Apr/13-Tue/09-45-15-937.log
 * @author James Stauffer
 */
public class DateFormatFileAppender extends FileAppender {

  /**
   * The default constructor does nothing.
   */
  public DateFormatFileAppender() {
  }

  /**
   * Instantiate a <code>DailyRollingFileAppender</code> and open the
   * file designated by <code>filename</code>. The opened filename will
   * become the ouput destination for this appender.
   */
  public DateFormatFileAppender (Layout layout, String filename) throws IOException {
    super(layout, filename, true);
  }

  private String fileBackup;//Saves the file pattern
  private boolean separate = false;

  public void setFile(String file) {
    super.setFile(file);
    this.fileBackup = getFile();
  }

  /**
   * If true each LoggingEvent causes that file to close and open.
   * This is useful when the file is a pattern that would often
   * produce a different filename.
   */
  public void setSeparate(boolean separate) {
    this.separate = separate;
  }

  protected void subAppend(LoggingEvent event) {
    if(separate) {
        try {//First reset the file so each new log gets a new file.
            setFile(getFile(), getAppend(), getBufferedIO(), getBufferSize());
        } catch(IOException e) {
            LogLog.error("Unable to reset fileName.");
        }
    }
    super.subAppend(event);
  }


  public
  synchronized
  void setFile(String fileName, boolean append, boolean bufferedIO, int bufferSize)
                                                            throws IOException {
    SimpleDateFormat sdf = new SimpleDateFormat(fileBackup);
    String actualFileName = sdf.format(new Date());
    makeDirs(actualFileName);
    super.setFile(actualFileName, append, bufferedIO, bufferSize);
  }

  /**
   * Ensures that all of the directories for the given path exist.
   * Anything after the last / or \ is assumed to be a filename.
   */
  private void makeDirs (String path) {
    int indexSlash = path.lastIndexOf("/");
    int indexBackSlash = path.lastIndexOf("\\");
    int index = Math.max(indexSlash, indexBackSlash);
    if(index > 0) {
        String dirs = path.substring(0, index);
//        LogLog.debug("Making " + dirs);
        File dir = new File(dirs);
        if(!dir.exists()) {
            boolean success = dir.mkdirs();
            if(!success) {
                LogLog.error("Unable to create directories for " + dirs);
            }
        }
    }
  }

}

Java에서 가능한지 모르겠지만 .NET에서 RollingFileAppender의 속성 STATICLOGFILENAME은 원하는 것을 제공합니다. 기본값은 사실입니다.

<staticLogFileName value="false"/>

전체 구성 :

<appender name="DefaultFileAppender" type="log4net.Appender.RollingFileAppender">
  <file value="application"/>
  <staticLogFileName value="false"/>
  <appendToFile value="true" />
  <rollingStyle value="Date" />
  <datePattern value="yyyy-MM-dd&quot;.log&quot;" />
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
  </layout>
</appender>

&quot;.log&quot; DateFormat가 로그에서 전역 날짜 패턴 'g'를 인식하지 못하게하는 것입니다.

이 예제는 매일 변경하려면 1 분마다 로거를 생성합니다. DatePattern 값.

<appender name="ASYNC" class="org.apache.log4j.DailyRollingFileAppender">
   <param name="File" value="./applogs/logger.log" />
   <param name="Append" value="true" />
   <param name="Threshold" value="debug" />
   <appendToFile value="true" />
   <param name="DatePattern" value="'.'yyyy_MM_dd_HH_mm"/>
   <rollingPolicy class="org.apache.log4j.rolling.TimeBasedRollingPolicy">
      <param name="fileNamePattern" value="./applogs/logger_%d{ddMMMyyyy HH:mm:ss}.log"/>
      <param name="rollOver" value="TRUE"/>
   </rollingPolicy>
   <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%d{ddMMMyyyy HH:mm:ss,SSS}^[%X{l4j_mdc_key}]^[%c{1}]^ %-5p %m%n" />
   </layout>
</appender>
<root>
   <level value="info" />
   <appender-ref ref="ASYNC" />
</root>

DailyrollingFileAppender를 언급하는 두 가지 답변에 대한 응답으로 (죄송합니다. 직접 언급 할 수있는 담당자가 충분하지 않으며 이것이 언급되어야한다고 생각합니다) 불행히도 해당 클래스의 개발자가이를 문서화했다고 경고 할 것입니다. 동기화 및 데이터 손실을 전시하며 새 배포를위한 대안을 추구해야합니다.

DailyrollingfileAppender Javadoc

당신은 설정할 수 있습니다 Fileappender 동적으로

SimpleLayout layout = new SimpleLayout();           
FileAppender appender = new FileAppender(layout,"logname."+new Date().toLocaleString(),false);
logger.addAppender(appender); 

@gedevan이 제안한 것처럼 dailyrollingfileAppender를 사용하더라도 여전히 logname.log.2008-10-10 (전날 로그가 보관되고 날짜가 파일 이름에 연결되기 때문에 하루가 지나면). 따라서 마지막에 .log를 원한다면 DatePattern에서 다음과 같이해야합니다.

log4j.appender.file.DatePattern='.'yyyy-MM-dd-HH-mm'.log'

라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top