我在我的asp.net应用程序中使用AdoNetAppender (SQL server),并希望在与SQL有任何连接问题的情况下使用RollingFileAppender。有没有办法将其配置为仅在AdoNetAppender出现问题时使用RollingFileAppender?
谢谢
更多
发布于 2009-05-08 07:22:11
在log4net中没有对这种故障转移场景的内置支持,问题是在log4net体系结构中,附加器是相互隔离的。
不过,一种常见的设置是让两个附加器并行记录,只是文件附加器只保留,比方说,一周的数据。如果AdoNetAppender失败,您将始终将最新数据保存在文件中。
但我在这里明确地看到了附加器的情况,它可以有一个子附加器的优先级列表,以便在发生故障时执行一些简单的故障转移。在the AppenderSkeleton上实现这两种构建应该不会太难。
发布于 2019-02-15 07:08:51
我已经实现了这样一个附加器,并在here和here (镜像)上发表了关于它的博客。代码可以在here上找到。
我扩展了AppenderSkeleton并创建了一个名为FailoverAppender的新附加器,它有两个AppenderSkeleton类型的成员。
PrimaryAppender和FailoverAppender的实际类型是使用log4net的xml配置语法配置的(参见下面的示例)。
一个片段:
public class FailoverAppender : AppenderSkeleton
{
private AppenderSkeleton _primaryAppender;
private AppenderSkeleton _failOverAppender;
....
}在Append方法的实现中,我默认情况下只向PrimaryAppender发送LoggingEvents,并用一个try-catch包围它。如果PrimaryAppender抛出(失败),我将发出一个标志并将LoggingEvent发送到FailoverAppender。下一个LoggingEvents将直接且仅发送到FailoverAppender。
protected override void Append(LoggingEvent loggingEvent)
{
if (LogToFailOverAppender)
{
_failOverAppender?.DoAppend(loggingEvent);
}
else
{
try
{
_primaryAppender?.DoAppend(loggingEvent);
}
catch
{
ActivateFailOverMode();
Append(loggingEvent);
}
}
}此外,我创建了一个自定义ErrorHandler,它将传播内部附加器异常,以在内部发出附加器失败的信号,这将使LoggingEvents仅被发送到FailoverAppender。
class FailOverErrorHandler : IErrorHandler
{
public FailOverAppender FailOverAppender { get; set; }
public FailOverErrorHandler(FailOverAppender failOverAppender)
{
FailOverAppender = failOverAppender;
}
public void Error(string message, Exception e, ErrorCode errorCode)
=> FailOverAppender.ActivateFailOverMode();
public void Error(string message, Exception e)
=> FailOverAppender.ActivateFailOverMode();
public void Error(string message)
=> FailOverAppender.ActivateFailOverMode();
}配置示例:
<!--This custom appender handles failovers. If the first appender fails, it'll delegate the message to the back appender-->
<appender name="FailoverAppender" type="MoreAppenders.FailoverAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger - %message%newline"/>
</layout>
<!--This is a custom test appender that will always throw an exception -->
<!--The first and the default appender that will be used.-->
<PrimaryAppender type="MoreAppenders.ExceptionThrowerAppender" >
<ThrowExceptionForCount value="1" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger - %message%newline"/>
</layout>
</PrimaryAppender>
<!--This appender will be used only if the PrimaryAppender has failed-->
<FailOverAppender type="log4net.Appender.RollingFileAppender">
<file value="log.txt"/>
<rollingStyle value="Size"/>
<maxSizeRollBackups value="10"/>
<maximumFileSize value="100mb"/>
<appendToFile value="true"/>
<staticLogFileName value="true"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger - %message%newline"/>
</layout>
</FailOverAppender>
</appender>https://stackoverflow.com/questions/836385
复制相似问题