在不同的.NET框架之间共享记录器

时间:2018-03-21 16:17:50

标签: c# .net .net-core asp.net-core-2.0 coreclr

我正在创建一个可以在.Net Core 1.2,.Net Core 2.0和.NET Framework 4.6+之间共享的应用程序框架。所以我选择我的项目的目标框架作为.NET标准。在我的框架项目中,我有工厂类,用于发送短信或电子邮件。在应用程序启动时,每个应用程序使用支持的服务将工厂配置为带有DI框架的单例实例。

public class MyFactory : IMyFactory
{
      private ILogger _logger;
      private IDictionary<string,IMyService> _container = new Dictionary<string,IMyService>();

    // this method is called on application startup to configure supported services
    public void Configure(string[] keys, ILogger logger)
    {  
        foreach(var key in keys)
        {
             if(key == "text")
             {
                 container.Add(key,new TextMessageService());
             }   

             if(key == "email")
             {
                 container.Add(key,new EmailService());
             }
        }
    }

    //application call this method to send message
    public bool SendMessage(string key, string message)
    {
         // we don't want application to stop when publish fail, so we add try-catch and log the message
         var flag = false;

         try
         {
             var service= container[key];
             service.Publish(message);
             flag = true;
         }
         class(Exception ex)
         {
            _logger.Error(ex);
         }

         return flag;
    }
}

问题:发布方法可能因任何原因失败。在这种情况下,我不希望应用程序停止,而框架应该记录错误消息。我的问题是因为框架可以在不同的.NET框架之间共享,我不知道我应该使用哪种ILooger可以在.NET Core和.NET Full之间共享。

我试图避免创建自己的ILogger界面。目前,所有应用程序都使用Serilog,但将来可能会更改。

可以在这里使用Microsoft.Extensions.Logging吗?

1 个答案:

答案 0 :(得分:5)

是的,它可以。如果你必须支持netcore 1,那么

Install-Package Microsoft.Extensions.Logging -Version 1.1.2 

会起作用:

但更好的 您的可重用组件只需要依赖Abstractions

Install-Package Microsoft.Extensions.Logging.Abstractions -Version 1.1.2 

您的组件只需要参考ILogger,使用您的组件的应用程序不依赖于使用MS扩展记录器。特别是,如果你看一下

的依赖关系
Serilog.Extensions.Logging -Version 2.0.2 

https://www.nuget.org/packages/Serilog.Extensions.Logging/,您可以看到它取决于Abstractions,但不依赖于MS Extensions记录器。 Serilog确实依赖于netstandard1.3。但是,netstandard版本页面再次告诉您所有目标都支持它。

使用框架的应用程序可以继续使用Serilog,只要他们知道如何将serilogger包装为MS.Extensions ILogger。 Serilog.Extensions.Logging中的SerilogLoggerProvider可以解决问题:

var msFrameworkLogger= new SerilogLoggerProvider(myExistingSerilog).CreateLogger("name");