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;
}
}
答案 0 :(得分:2)
您需要将自定义提供程序插入Serilog(作为接收器)。 Serilog取代了整个默认的日志记录管道,以提高效率,因此没有两组级别控制和过滤器保持同步。