Отдельный файл журнала для отдельного потока с использованием serilog

#c# #.net #serilog #serilog-sinks-file

Вопрос:

У меня есть.Приложение службы Net Worker, имеющее несколько потоков. Я хочу записать каждый поток в отдельный файл, чтобы облегчить чтение журналов. Есть какие-нибудь идеи для реализации этого?

Комментарии:

1. Лично я просто опускаюсь до правильного агрегатора журналов, такого как SEQ или что-то еще. Структурируйте свои журналы так, как вы хотите, и никогда больше не беспокойтесь о файлах, если только они не будут сохранены

2. Пожалуйста, предоставьте достаточно кода, чтобы другие могли лучше понять или воспроизвести проблему.

Ответ №1:

Распространенный способ решить, в какой приемник писать во время выполнения,-использовать Serilog.Раковины.Карта:

 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();
 

При использовании этого подхода следует рассмотреть возможность ограничения количества открытых приемников.