我正在使用 log4j AsyncAppender
。我编写了自己的附加程序来自定义记录器,如下所示。
公共类 MyAppender 扩展 AppenderSkeleton {
@Override
public void close() {
}
@Override
public boolean requiresLayout() {
return false;
}
@Override
protected void append(LoggingEvent event) {
//Here am doing some logic which will connect database and fetch some records.
}
}
我的 log4j 配置:
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">
<!-- Appenders -->
<appender name="stdout" class="com.sample.MyAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %p [%c] - %m%n"/>
</layout>
</appender>
<appender name="ASYNC" class="org.apache.log4j.AsyncAppender">
<param name="BufferSize" value="500"/>
<appender-ref ref="stdout"/>
</appender>
<root>
<level value="INFO" />
<appender-ref ref="ASYNC" />
</root>
</log4j:configuration>
现在一切正常。我MyAppender
将触发一个Select
查询并从表中获取一些详细信息并使用 java 邮件 API 发送这些详细信息。正如我正在使用AsyncAppender
的那样,它不会阻塞现有的正在运行的线程,并且 MyAppender 逻辑是异步执行的。我的问题是,如果主线程在逻辑完成之前完成它的执行,那么即使主线程也能MyAppender
保证逻辑将完成MyAppender
完成执行?
谢谢!