我想将日志信息发送到“审核”文件。我考虑过将 log4j 与专用 Appender 一起使用:
LOGGER_AUDIT.info("Text of audit");
我想确保它是同步写入的。如果出现异常,比如这样:
og4j:ERROR setFile(null,true) call failed.
java.io.FileNotFoundException: D:audit.log (Access denied)
...
我想捕获它并停止执行。
它会是这样的:
try {
LOGGER_AUDIT.info("Text of audit");
} catch(LoggerException logExc) {
// TODO Ops... the logger do not write.
throw logExc;
}
您可以通过调用强制 log4j 配置处理:
BasicConfigurator.resetConfiguration();
DOMConfigurator.configureAndWatch( log4jConfigPath );
要捕获异常,您可以使用 ErrorHandler 功能。 https://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/spi/ErrorHandler.html
配置方式如下:
<appender name="file" class="org.apache.log4j.DailyRollingFileAppender">
<errorHandler class="org.apache.log4j.varia.FallbackErrorHandler">
<root-ref/>
<appender-ref ref="console"/>
</errorHandler>
<param name="File" value="C:/temp/test.log"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %-5p %30.30c - %m%n"/>
</layout>
</appender>
您可以放置自己的 ErrorHandler 而不是 FallbackErrorHandler。默认情况下使用 OnlyOnceErrorHandler。它将异常打印到 STDERR。
我是一名优秀的程序员,十分优秀!