Serilog 读取配置

Serilog ReadFrom Configuration

我正在尝试使用 Serilog.Settings.Configuration 预发布 NuGet 包从 appsettings.json 加载我的 Serilog 配置。但是,当我使用 Configuration.GetSection 加载它时,该值继续返回为 null。

这是我的 Program.cs 文件中的内容:

    return WebHost.CreateDefaultBuilder(args)
    .UseStartup<Startup>()
    .ConfigureLogging(
        (hostingContext, loggingBuilder) =>
        {
            loggingBuilder.ClearProviders();
            loggingBuilder.AddSerilog(
                new LoggerConfiguration()
                    .ReadFrom.ConfigurationSection(hostingContext.Configuration.GetSection("Serilog"))
                    .CreateLogger()
            );
        }
    );

这是我的 appsettings.json 文件中的内容:

    {
    "Serilog": {
        "Using": [ "Serilog.Sinks.MSSqlServer" ],
        "MinimumLevel": {
            "Default": "Verbose",
            "Override": {
                "Microsoft": "Verbose",
                "System": "Verbose",
                "Microsoft.AspNetCore.Authentication": "Verbose"
            }
        },
        "WriteTo": [
            {
                "Name": "MSSqlServer",
                "Args": {
                    "connectionString": "*my_connectionString*",
                    "tableName": "ErrorLog"
                }
            }
        ]
    }}

安装的 NuGet 包:

我是这样配置的:

return WebHost.CreateDefaultBuilder(args)
            .UseStartup<Startup>()
            .UseSerilog((hostingContext, loggerConfiguration) => loggerConfiguration
                .ReadFrom.Configuration(hostingContext.Configuration))
            .Build();

默认情况下 Serilog 在配置中查找 Serilog 部分

我是这样配置的

     public static void Main(string[] args)
     {
        var _config = new ConfigurationBuilder()
                    .AddJsonFile("loggerconfig.json")//mantained separate 
     config file.
                    .Build();
        Log.Logger = new LoggerConfiguration()
                    .ReadFrom.Configuration(_config)
                    .CreateLogger();
        CreateWebHostBuilder(args).Build().Run();
    }

    public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
        WebHost.CreateDefaultBuilder(args)
            .UseSerilog()
            .UseStartup<Startup>();

根据 Serilog,这是更好的方法。

这是我从 logging.json 读取的方法:

            var builder = new ConfigurationBuilder()
                .AddJsonFile(path: "logging.json", optional: false, reloadOnChange: true);

            var config = builder.Build();
            Log.Logger = new LoggerConfiguration()
                        .Enrich.With(new EventBusLogEnricher())
                        .ReadFrom.Configuration(config)
                        .CreateLogger();