gpt4 book ai didi

c# - Serilog 不将日志写入文件

转载 作者:行者123 更新时间:2023-11-30 15:17:39 27 4
gpt4 key购买 nike

我有解决方案,其中有 5 个 .net-core 项目,一个是控制台应用程序,其余是类库。在主要功能的类程序中,我有:

        Log.Logger = new LoggerConfiguration()
.MinimumLevel.Debug()
.WriteTo.LiterateConsole()
.WriteTo.Async(a => a.RollingFile("logs\\myapp-{Date}.txt",
outputTemplate : "{Timestamp:yyyy-MM-dd HH:mm:ss.fff zzz} [{Level} {Type}] {Message}{NewLine}{Exception} {SourceContext}"))
.CreateLogger();

Log.Information("Server starting ...");

//Here I have class which invoke a lot of(6-7) Tasks
NewTask task = new NewTask();
task.Start();
//And I end my Main function with
Log.CloseAndFlush();
Console.ReadLine();

在我的所有类(class)中,当我捕获异常时,我写了:

        catch(Exception e)
{
Log.ForContext<ClassName>().Error(e, "Somethign went wrong");
}

在新日志中,我只有“服务器正在启动...”,仅此而已。我应该做什么?当我调试时,我看到我的程序运行了 catch 行。现在我不知道该怎么办。也许有人有类似的问题?

编辑我从这里建模 https://github.com/serilog/serilog/wiki/Getting-Started

最佳答案

您只应在所有任务完成后调用 Log.CloseAndFlush()。将它放在 Console.ReadLine() 调用之后应该可以证明这一点。

关于c# - Serilog 不将日志写入文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45875644/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com