Serilog - как сделать собственный формат вывода консоли?

Я использую Serilog с serilog-sinks-console в моем проекте C#, и мне интересно, как я могу изменить формат вывода консоли, не создавая совершенно новый модуль форматирования. Мне просто нужно настроить одну информацию java (slf4j/logback), например формат.

Из этого:

00:19:49 [DBG] Microsoft.AspNetCore.Hosting.Internal.WebHost - App starting
00:19:49 [DBG] Microsoft.AspNetCore.Hosting.Internal.WebHost - App started

в это:

00:19:49 [DBG] m.a.h.i.WebHost - App starting
00:19:49 [DBG] m.a.h.i.WebHost - App started

или просто этот простой формат:

00:19:49 [DBG] WebHost - App starting
00:19:49 [DBG] WebHost - App started

person mojmir.novak    schedule 01.06.2018    source источник
comment
Добавьте обогатитель для создания нового свойства; затем укажите его в строке формата. Или изменить текущий SourceContext в Enricher. (это точно не в коробке)   -  person Ruben Bartelink    schedule 02.06.2018


Ответы (2)


Спасибо за направление к @Ruben Bartelink. Если кому-то еще будет интересно, как это сделать, вот простой пример:

Обогатитель:

class SimpleClassEnricher : ILogEventEnricher
{
  public void Enrich(LogEvent logEvent, ILogEventPropertyFactory propertyFactory)
  {
    var typeName = logEvent.Properties.GetValueOrDefault("SourceContext").ToString();
    var pos = typeName.LastIndexOf('.');
    typeName = typeName.Substring(pos + 1, typeName.Length - pos - 2);
    logEvent.AddOrUpdateProperty(propertyFactory.CreateProperty("SourceContext", typeName));
  }
}

затем использование:

Log.Logger = new LoggerConfiguration()
    .MinimumLevel.Debug()
    .Enrich.With(new SimpleClassEnricher())
    .WriteTo.Console(outputTemplate: "{Timestamp:HH:mm:ss} [{Level:u3}] {SourceContext} - {Message:lj}{NewLine}{Exception}")
    .CreateLogger();
person mojmir.novak    schedule 02.06.2018

F# рифф на ответ Моймира (HT @Kostas Rontogiannis):

    /// Converts SourceContext which is the fully qualified type name to a short version, using just the type name.
    type SourceContextShortEnricher () =
        interface Serilog.Core.ILogEventEnricher with
            member __.Enrich(logEvent : Serilog.Events.LogEvent, lepf : Serilog.Core.ILogEventPropertyFactory) =
                match logEvent.Properties.TryGetValue "SourceContext" with
                | true, (:? Serilog.Events.ScalarValue as v) when v <> null && v.Value <> null ->
                    let typeName =
                        string v.Value
                        |> fun s -> match s.LastIndexOf("[[") with -1 -> s | pos -> s.Substring(0, pos)
                        |> fun s -> match s.LastIndexOf('.') with -1 -> s | idx when s.Length = idx - 1 -> s | idx -> s.Substring(idx + 1)
                    logEvent.AddPropertyIfAbsent(lepf.CreateProperty("SourceContextShort", typeName))
                    logEvent.RemovePropertyIfPresent "SourceContext"
                | _ -> ()

person Ruben Bartelink    schedule 21.09.2020