使用serilog为单独的线程提供单独的日志文件

1 .net c# serilog serilog-sinks-file

我有一个具有多个线程的 .Net Worker Service 应用程序。我想将每个线程记录到单独的文件中,以便更轻松地阅读日志。有什么想法来实现这个吗?

Cai*_*ete 5

决定在运行时写入哪个接收器的常见方法是使用Serilog.Sinks.Map

Log.Logger = new LoggerConfiguration()
    .WriteTo.Map(_ => Thread.CurrentThread.ManagedThreadId,
        (threadId, wt) => wt.File($"log-{threadId}.log"))
.CreateLogger();

Log.Information("Hello from the main thread");

var task1 = Task.Run(() => Log.Information("Hello from thread X"));
var task2 = Task.Run(() => Log.Information("Hello from thread Y"));

Task.WaitAll(task1, task2);

Log.CloseAndFlush();
Run Code Online (Sandbox Code Playgroud)

使用此方法时,您应该考虑限制开放接收器的数量。