Log4j FileAppender recreating deleted files

后端 未结 5 1767
悲哀的现实
悲哀的现实 2021-01-03 07:08

I am using Log4j as logging framework in a project I am working on. I have the following situation: Log4j is configured to write the logs into a log file. At some point, thi

5条回答
  •  没有蜡笔的小新
    2021-01-03 07:25

    Try This Class

    package wodong.test;
    import java.io.File;
    import java.io.IOException;
    
    import org.apache.log4j.FileAppender;
    import org.apache.log4j.spi.LoggingEvent;
    
    public class LastFileAppender extends FileAppender {
        @Override
        public void append(LoggingEvent event) {
            checkLogFileExist();
            super.append(event);
        }
        private void checkLogFileExist(){
            File logFile = new File(super.fileName);
            if (!logFile.exists()) {
                try {
                    logFile.createNewFile();
                } catch (IOException e) {
                    System.out.println("Error while create new log file.");
                }
            }
        }
    }
    

    Also edit the log4j config file

    log4j.appender.R=wodong.test.LastFileAppender
    

提交回复
热议问题