我在 logback 文件中设置了两个日志文件。
<appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>/opt/loghome/${instance}/recon.%d{MM-dd-yyyy}.log.zip
</fileNamePattern>
<maxHistory>30</maxHistory>
</rollingPolicy>
<append>false</append>
<encoder>
<pattern>%d{MM/dd/yyyy HH:mm:ss.SSS} [%thread] %-5level %logger{36} -%X{User} %msg%n</pattern>
</encoder>
</appender>
<appender name="datafile1" class="ch.qos.logback.core.FileAppender">
<file>/opt/loghome/datafiles/file1.log</file>
<append>false</append>
<encoder>
<pattern>%msg%n</pattern>
</encoder>
</appender>
在java中,这些设置如下:
private static final Logger logger = LoggerFactory
.getLogger(Main.class);
和
private static final Logger logger = LoggerFactory
.getLogger("datafile1");
第一个是标准应用程序日志文件。第二个存储程序从数据库中检索的数据。
然后程序比较日志文件中的数据并发送一些结果。完成后,我想清除此日志(datafile1),使其为空并为下一次运行做好准备。我怎样才能做到这一点?
注意,该程序是一个 24 小时进程,它使用调度程序来运行此作业。它不会在每次运行作业时重新启动。