Serilog排除了自定义记录器提供程序

时间:2018-06-18 22:33:28

标签: c# logging asp.net-core asp.net-core-mvc serilog

Serilog工作得很好,但我注意到它似乎排除了我设置的任何自定义记录器提供程序。

当我的Startup中有UseSerilog()时,我的CustomProvider永远不会被创建(CreateLogger永远不会被调用)。

是否仍然可以使用Serilog的自定义提供程序?

//class Program, Main Method
WebHost.CreateDefaultBuilder(args)
    .UseConfiguration(config)
    .UseSerilog() //after adding this, my Custom Logger never gets called 
    .UseStartup<Startup>()
    .Build();


//class Startup
public void Configure(IApplicationBuilder app, ILoggerFactory logger, IServiceProvider serviceProvider)
{
    logger.AddProvider(new CustomProvider(serviceProvider));
}

public class CustomProvider : ILoggerProvider
{
    private readonly IServiceProvider _serviceProvider;

    public void Dispose()
    {
    }

    public CustomProvider(IServiceProvider serviceProvider)
    {
        _serviceProvider = serviceProvider;
    }

    //--------------never gets called---------------
    public ILogger CreateLogger(string categoryName)
    {
        var logger = _serviceProvider.GetService<CustomLogger>();
        logger.LogLevel = LogLevel.Error;

        return logger;
    }
}

1 个答案:

答案 0 :(得分:2)

您需要将自定义提供程序插入Serilog(作为接收器)。 Serilog取代了整个默认的日志记录管道,以提高效率,因此没有两组级别控制和过滤器保持同步。

这篇文章的背景是:https://nblumhardt.com/2017/08/use-serilog/