繁体   English   中英

Serilog 不记录

[英]Serilog not logging

我有以下配置

public static IServiceCollection ConfigureSiteLogging(this IServiceCollection services)
{
    if (!Directory.Exists(@"D:\inetpub\logs"))
    {
        Directory.CreateDirectory(@"D:\inetpub\logs");
    }

    services.AddLogging(builder =>
    {

        ILoggerFactory loggerFactory = LoggerFactory.Create(builder =>
        {
            var loggerConfiguration = new LoggerConfiguration()
                                        .Enrich.FromLogContext()
                                        .WriteTo.File(@"D:\inetpub\logs\shop.txt"
                                                    , rollingInterval: RollingInterval.Day
                                                    , encoding: System.Text.Encoding.UTF8
                                                    , retainedFileCountLimit: 2
                                                    , restrictedToMinimumLevel: Serilog.Events.LogEventLevel.Information
                                                    );

            builder.AddSerilog(loggerConfiguration.CreateLogger());

        });
    });
    return services;
}

在站点程序文件中:

Log.Information("Web Service Running");
await app.RunAsync();
Log.Information("Web Service Stopped");
Log.CloseAndFlush();

问题是我在磁盘上看不到日志,为什么不刷新? 这些是我的 NuGet 包

<PackageReference Include="Serilog" Version="2.11.0" />
<PackageReference Include="Serilog.AspNetCore" Version="6.0.1" />
<PackageReference Include="Serilog.Extensions.Logging" Version="3.1.0" />
<PackageReference Include="Serilog.Settings.AppSettings" Version="2.2.2" />
<PackageReference Include="Serilog.Settings.Configuration" Version="3.3.0" />
<PackageReference Include="Serilog.Sinks.File" Version="5.0.0" />

我找到了我错过的东西,不确定它是否是一项功能,但您必须将记录器分配给Serilog.Log.Logger ,对 builder.AddSerilog() 的调用不会执行该步骤...

这是我的工作解决方案

public static IServiceCollection ConfigureSiteLogging(this IServiceCollection services)
{
    if (!Directory.Exists(@"D:\InetPub\logs"))
    {
        Directory.CreateDirectory(@"D:\InetPub\logs");
    }
    Log.Logger = new LoggerConfiguration()
                    .Enrich.FromLogContext()
                    .MinimumLevel.Information()
                    .WriteTo.File(@"D:\InetPub\logs\shop.txt"
                                , rollingInterval: RollingInterval.Day
                                , encoding: System.Text.Encoding.UTF8
                                , retainedFileCountLimit: 2
                                , flushToDiskInterval: TimeSpan.FromSeconds(5)
                                , shared: true
                                ).CreateLogger();

    services.AddLogging(builder =>
    {
        ILoggerFactory loggerFactory = LoggerFactory.Create(builder =>
        {
            builder.AddSerilog(Log.Logger);
        });
    });
    return services;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM