Log4net пользовательских сообщений JSON в консоли /FileAppender

Мне нужно войти с log4net на несколько целей (loggly, console, file). Для loggly мне нужно войти в JSON для некоторых метаданных, чтобы найти журналы. Я изменяю объект сообщения для этого, добавляя метаданные к динамическому объекту сообщения следующим образом (пример темы).

public void Info(string message)
    {
        log.Info(GetLogObject(message));
    }

private object GetLogObject(string message, Exception ex = null)
    {
        dynamic obj = new ExpandoObject();

        obj.message = message;
        obj.exception = ex;
        obj.subject = _configuration.SubjectId;

        return obj;
    }

app.config

<log4net>
<root>
  <level value="ALL" />
  <appender-ref ref="ConsoleAppender" />
  <appender-ref ref="RollingFileAppender" />
  <appender-ref ref="LogglyAppender" />
</root>
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date - %message%newline" />
  </layout>
</appender>
<appender name="LogglyAppender" type="log4net.loggly.LogglyAppender, log4net-loggly">
  <rootUrl value="https://logs-01.loggly.com/" />
  <inputKey value="*" />
  <tag value="AppTag" />
  <filter type="log4net.Filter.LevelRangeFilter">
    <levelMin value="ERROR" />
    <levelMax value="FATAL" />
  </filter>
</appender>
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
  <file value="Logs/rolling.log" />
  <appendToFile value="true" />
  <rollingStyle value="Size" />
  <maxSizeRollBackups value="5" />
  <maximumFileSize value="10MB" />
  <staticLogFileName value="true" />
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date %level - %message%newline" />
  </layout>
</appender>

Теперь Console и FileAppenders регистрируют JSON следующим образом:

2017-06-12 15:28:10,236 INFO - {[message, Will collect every 1 Hours, 0 Minutes and 0 Seconds], [exception, ], [subject, 11111111-1111-1111-1111-111111111111]}
2017-06-12 15:28:10,271 INFO - {[message, Collection Round started at 12.06.2017 13:28:10], [exception, ], [subject, 11111111-1111-1111-1111-111111111111]}

Я хочу, чтобы эти appenders просто регистрировали само сообщение (obj.message) так:

2017-06-12 15:28:10,236 INFO - Will collect every 1 Hours, 0 Minutes and 0 Seconds
2017-06-12 15:28:10,271 INFO - Collection Round started at 12.06.2017 11:17:29

Как я могу это сделать? Большое спасибо:)

1 ответ

Что произойдет, если вы создадите свой собственный тип для объекта сообщения (вместо использования динамического объекта) и переопределите ToString() метод? Я подозреваю, LogglyAppender будет отображать график в то время как регулярный PatternLayout прибегнет к ToString(), Я не пробовал это, только подсказка. Вы могли бы, возможно, подкласс ExpandoObject не потерять эту динамику.

Другие вопросы по тегам