Отдельный вход в несколько файлов журналов - PullRequest
2 голосов
/ 24 апреля 2019

Я пытаюсь настроить Serilog для разделения обычных журналов и ведения журнала сущности.Вот моя конфигурация serilog:

"Serilog": {
"Using": [
  "Serilog.Settings.Configuration",
  "Serilog.Sinks.File"
],
"MinimumLevel": {
  "Default": "Debug",
  "Override": {
    "Microsoft": "Debug",
    "System": "Warning"
  }
},
"WriteTo": [
  {
    "Name": "RollingFile",
    "Args": {
      "configureLogger": {
        "WriteTo": [
          {
            "Name": "LogFile",
            "Args": {
              "textFormatter": "JsonFormatter",
              "fileSizeLimitBytes": 2147483648,
              "retainedFileCountLimit": 5
            }
          }
        ]
      },
      "pathFormat": "log-{Date}.log",
      "logDirectory": ".",
      "Filter": [
        {
          "Name": "ByExcluding",
          "Args": {
            "expression": "StartsWith(SourceContext, 'Microsoft.EntityFrameworkCore.')"
          }
        }
      ]
    }
  },
  {
    "Name": "RollingFile2",
    "Args": {
      "configureLogger": {
        "WriteTo": [
          {
            "Name": "LogFile2",
            "Args": {
              "textFormatter": "JsonFormatter",
              "fileSizeLimitBytes": 2147483648,
              "retainedFileCountLimit": 5
            }
          }
        ]
      },
      "pathFormat": "log-DB-{Date}.log",
      "logDirectory": ".",
      "Filter": [
        {
          "Name": "ByIncluding",
          "Args": {
            "expression": "StartsWith(SourceContext, 'Microsoft.EntityFrameworkCore.')"
          }
        }
      ]
    }
  },
  {
    "Name": "Console",
    "Args": {
      "outputTemplate": "{Timestamp:HH:mm:ss} [{Level}] ({CorrelationToken}) {Message}{NewLine}{Exception}"
    }
  }
],
"Enrich": [
  "FromLogContext",
  "WithMachineName",
  "WithProcessId",
  "WithThreadId",
  "WithHttpRequestId"
]

}

Я не получаю второй файл журнала.Я основываюсь на этом посте, чтобы реализовать свою конфигурацию Фильтровать журналы Serilog для различных приемников в зависимости от источника контекста?

Что я не понял в конфигурации serilog?Я нахожу много примеров конфигурации через код, но очень мало - через appsettings.json.Я предпочитаю использовать appsetting.json

Спасибо.

1 Ответ

1 голос
/ 16 мая 2019

Вы должны настроить суб-логгеры, а не перекатывать файлы.У вас есть две записи в вашем массиве WriteTo, но обе "Name": "RollingFile".Измените их на "Name": "Logger", а затем переместите конфиги фильтра в соответствующие разделы configureLogger этих суб-регистраторов.Примерно так:

    "WriteTo": [
      {
        "Name": "Logger",
        "Args": {
          "configureLogger": {
            "WriteTo": [
              {
                "Name": "File",
                "Args": {
                  "path": "log-{Date}.log",
                  "retainedFileCountLimit": 5,
                  "fileSizeLimitBytes": 2147483648,
                }
              }
            ],
            "Filter": [
              {
                "Name": "ByExcluding",
                "Args": {
                  "expression": "StartsWith(SourceContext, 'Microsoft.EntityFrameworkCore.')"
                }
              }
            ]
          }
        }
      },
      {
        "Name": "Logger",
        "Args": {
          "configureLogger": {
            "WriteTo": [
              {
                "Name": "File",
                "Args": {
                  "path": "log-db-{Date}.log",
                  "retainedFileCountLimit": 5,
                  "fileSizeLimitBytes": 2147483648,
                }
              }
            ],
            "Filter": [
              {
                "Name": "ByIncluding",
                "Args": {
                  "expression": "StartsWith(SourceContext, 'Microsoft.EntityFrameworkCore.')"
                }
              }
            ]
          }
        }
      }
    ],

В моих тестах все еще есть пространства имен Microsoft.AspNetCore и Microsoft.Extensions, проходящие через второй фильтр - поэтому не уверен, что ByIncluding блокирует, как ByExcluding.И я не уверен, какие другие типы фильтров доступны для этого.

Обновление

Просто видел в другом месте, что это похоже на другой тип фильтра, который вы можете попробовать:"Name": "ByIncludingOnly".

...