Отдельный файл журнала для отдельного потока с использованием serilog
У меня есть приложение .Net Worker Service с несколькими потоками. Я хочу регистрировать каждый поток в отдельном файле, чтобы упростить чтение журналов. Есть идеи по реализации этого?
1 ответ
Обычный способ решить, в какой приемник писать во время выполнения, - использовать 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();
При использовании этого подхода вам следует подумать об ограничении количества открытых раковин .