首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Log4net -在AdoNetAppender和RollingFileAppender之间动态切换附加器

Log4net -在AdoNetAppender和RollingFileAppender之间动态切换附加器
EN

Stack Overflow用户
提问于 2009-05-07 18:53:14
回答 2查看 2.2K关注 0票数 7

我在我的asp.net应用程序中使用AdoNetAppender (SQL server),并希望在与SQL有任何连接问题的情况下使用RollingFileAppender。有没有办法将其配置为仅在AdoNetAppender出现问题时使用RollingFileAppender?

谢谢

更多

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-05-08 07:22:11

在log4net中没有对这种故障转移场景的内置支持,问题是在log4net体系结构中,附加器是相互隔离的。

不过,一种常见的设置是让两个附加器并行记录,只是文件附加器只保留,比方说,一周的数据。如果AdoNetAppender失败,您将始终将最新数据保存在文件中。

但我在这里明确地看到了附加器的情况,它可以有一个子附加器的优先级列表,以便在发生故障时执行一些简单的故障转移。在the AppenderSkeleton上实现这两种构建应该不会太难。

票数 4
EN

Stack Overflow用户

发布于 2019-02-15 07:08:51

我已经实现了这样一个附加器,并在herehere (镜像)上发表了关于它的博客。代码可以在here上找到。

我扩展了AppenderSkeleton并创建了一个名为FailoverAppender的新附加器,它有两个AppenderSkeleton类型的成员。

  • 名为"PrimaryAppender“的默认附加器-默认情况下一直使用,直到失败为止。
  • 名为"FailoverAppender”的故障转移附加器-仅在主服务器出现故障后使用。

PrimaryAppender和FailoverAppender的实际类型是使用log4net的xml配置语法配置的(参见下面的示例)。

一个片段:

代码语言:javascript
复制
public class FailoverAppender : AppenderSkeleton
{
    private AppenderSkeleton _primaryAppender;
    private AppenderSkeleton _failOverAppender;
     ....
}

在Append方法的实现中,我默认情况下只向PrimaryAppender发送LoggingEvents,并用一个try-catch包围它。如果PrimaryAppender抛出(失败),我将发出一个标志并将LoggingEvent发送到FailoverAppender。下一个LoggingEvents将直接且仅发送到FailoverAppender。

代码语言:javascript
复制
protected override void Append(LoggingEvent loggingEvent)
{
    if (LogToFailOverAppender)
    {
        _failOverAppender?.DoAppend(loggingEvent);
    }
    else
    {
        try
        {
            _primaryAppender?.DoAppend(loggingEvent);
        }
        catch
        {
            ActivateFailOverMode();
            Append(loggingEvent);
        }
    }
}

此外,我创建了一个自定义ErrorHandler,它将传播内部附加器异常,以在内部发出附加器失败的信号,这将使LoggingEvents仅被发送到FailoverAppender。

代码语言:javascript
复制
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();
}

配置示例:

代码语言:javascript
复制
<!--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>
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/836385

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档