微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 使用DI Simple Injector的log4net

我正在尝试使用Simple Injector(集成MVC)v 2.5.2.对于MVC 4应用程序,我也需要跟踪/记录性能(执行)(通过log4net模块).当前实现(在运行时)在指定的路径中创建log4net文件,但没有写入任何文本行(当我调试它时,一切都没有错误到_logger.Info(“message”)的结尾).

有没有人尝试使用Simple Injector DI for log4net?

注册log4net模块的方式是:

public static class LoggingModule
{
    public static void RegisterServices(Container container)
    {
        string log4NetConfigFile = Path.Combine(AppDomain.CurrentDomain.BaseDirectory,"log4net.config");
        log4net.Config.XmlConfigurator.ConfigureAndWatch(new FileInfo(log4NetConfigFile));
        var logger = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
        container.RegisterSingle(logger);

    }
}

并在Global.asax

LoggingModule.RegisterServices(container);

Log4net配置文件看起来像这样(我不认为有任何问题):

<log4net>
  <appender name="PerformanceLogFile" type="log4net.Appender.RollingFileAppender" >
  <param name="File" value="..\Performance\PricingManager" />
  <param name="AppendToFile" value="true" />
  <param name="RollingStyle" value="Date" />
  <param name="DatePattern" value="_yyyy-MM-dd.lo\g" />
  <param name="MaxSizeRollBackups" value="10" />
  <param name="StaticLogFileName" value="false" />
  <layout type="log4net.Layout.PatternLayout">
    <param name="ConversionPattern" value="%m%n"/>
  </layout>
  <filter type="log4net.Filter.LevelRangeFilter">
    <param name="LevelMin" value="INFO" />
    <param name="LevelMax" value="FATAL" />
  </filter>
  </appender>
  <logger name="SoftTech.PricingEngine.PricingService.PerformanceStatisticLoggerWithAPI">
    <level value="ALL" />
    <appender-ref ref="PerformanceLogFile" />
  </logger>
</log4net>

并打开/关闭我一直在使用的日志记录:

private static void RegisterIPerformanceStatisticLogger(Container container)
    {
        if (ShouldLogperformance())
        {
            container.Register<IPerformanceStatisticLogger,PerformanceStatisticLogger>(WebLifestyle); 
        }
        else
        {
            // do nothing
            container.Register<IPerformanceStatisticLogger,disabledPerformanceStatisticLogger>(WebLifestyle); 
        }
    }

并且PerformanceStatisticLogger或disablePerformanceStatisticLogger设置

IsLoggingEnabled = true; // | false
IsAPITraceEnabled = false; // | true

我做错了什么?在我看来注射方式的问题.
谢谢你的建议

解决方法

在配置log4net时,Simple Injector没有什么特别之处.例如,您可以按如下方式注册ILog:
container.RegisterSingleton<ILog>(LogManager.GetLogger(typeof(object)));

显然,这为整个应用程序注册一个记录器.如果您想为每个类注入不同的记录器,则必须定义自己的适配器实现:

public sealed class Log4NetAdapter<T> : LogImpl
{
    public Log4NetAdapter() : base(LogManager.GetLogger(typeof(T)).Logger) { }
}

您可以按如下方式注册此适配器:

container.RegisterConditional(typeof(ILog),c => typeof(Log4NetAdapter<>).MakeGenericType(c.Consumer.ImplementationType),Lifestyle.Singleton,c => true);

这确保了每个消费者获得其自己的Log4NetAdapter< T>.实现.

请注意,尽管IMO最好阻止应用程序代码依赖第三方库抽象.我认为define you own logger abstraction要好得多.

我对log4net的体验是,当log4net没有记录任何内容时,你的log4net配置有问题.我讨厌log4net的原因是,当你配置错误时它永远不会抛出任何异常.它只是吞下并继续,这使得使用log4net比应该更痛苦.

有一点可以帮助就是在启动时挂起log4net的LogLog.LogReceived事件.这允许您检查是否有任何错误.例如,这是我在之前项目中使用的代码

LogLog.LogReceived += (s,e) =>
{
    if (e.LogLog.Prefix.Contains("ERROR"))
    {
        throw new ConfigurationErrorsException(e.LogLog.Message,e.LogLog.Exception);
    }
};

当log4net配置错误时,这可以确保您的应用程序直接停止,但有明确的异常.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


原文地址:http://msdn.microsoft.com/en-us/magazine/cc163791.aspx 原文发布日期: 9/19/2005 原文已经被 Microsoft 删除了,收集过程中发现很多文章图都不全,那是因为原文的图都不全,所以特收集完整全文。 目录 前言 CLR启动程序
前言 随着近些年微服务的流行,有越来越多的开发者和团队所采纳和使用,它的确提供了很多的优势也解决了很多的问题,但是我们也知道也并不是银弹,提供优势的同时它也给我们的开发人员和团队也带来了很多的挑战。 为了迎接或者采用这些新技术,开发团队需要更加注重一些流程或工具的使用,这样才能更好的适应这些新技术所
最近因为比较忙,好久没有写博客了,这篇主要给大家分享一下PLINQ中的分区。上一篇介绍了并行编程,这边详细介绍一下并行编程中的分区和自定义分区。 先做个假设,假设我们有一个200Mb的文本文件需要读取,怎么样才能做到最优的速度呢?对,很显然就是拆分,把文本文件拆分成很多个小文件,充分利用我们计算机中
在多核CPU在今天和不久的将来,计算机将拥有更多的内核,Microsoft为了利用这个硬件特性,于是在Visual Studio 2010 和 .NET Framework 4的发布及以上版本中,添加了并行编程这个新特性,我想它以后势必会改变我们的开发方式。 在以前或者说现在,我们在并行开发的时候可
c语言输入成绩怎么判断等级
字符型数据在内存中的存储形式是什么
c语言怎么求字符串的长度并输出
c语言函数的三种调用方式是什么
c语言中保留两位小数怎么表示
double的输入格式符是什么