Настройки nlog для сайта ASP .NET Core 2.1 - PullRequest
0 голосов
/ 14 сентября 2018

Я пытаюсь настроить nlog для входа в 3 отдельных файла журнала. Я хочу, чтобы материал Entity Framework шел в один файл журнала (db.log). Я хочу, чтобы журналирование, связанное с приложением, осуществлялось только в другой файл журнала (own.log). И, наконец, я хочу, чтобы все остальное (материал Microsoft) перешло к еще одному файлу (all.log)

Это то, что у меня есть ниже, но я не могу заставить работать логи в соответствии с моими требованиями. Что я делаю не так?

Заранее спасибо!

<?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      autoReload="true"
      internalLogFile="internal.log"
      internalLogLevel="info" >

  <!-- enable asp.net core layout renderers -->
  <extensions>
    <add assembly="NLog.Web.AspNetCore"/>
  </extensions>

  <!-- the targets to write to -->
  <targets>

    <!-- write logs to file  -->
    <target xsi:type="File" name="allfile" 
            fileName="all-${shortdate}.log"
            layout="${longdate}|${event-properties:item=EventId_Id}|${uppercase:${level}}|${logger}|${message} ${exception:format=tostring}" />

    <!-- another file log, only own logs. Uses some ASP.NET core renderers -->
    <target xsi:type="File" name="ownFile-web"
            fileName="own-${shortdate}.log"
            layout="${longdate}|${activityid}|${level:uppercase=true}|${message} ${exception:format=ToString}|${logger}|${all-event-properties}|url: ${aspnet-request-url}|action: ${aspnet-mvc-action}" />

    <target xsi:type="File" name="sqllogfile"
            fileName="db-${shortdate}.log"
            layout="${date}|${activityid}|${level:uppercase=true}|${message} ${exception}|${logger}|${all-event-properties}" />

  </targets>

  <!-- rules to map from logger name to target -->
  <rules>
    <!--All logs, including from Microsoft-->
    <logger name="*" minlevel="Trace" writeTo="allfile" />

    <!--Skip Microsoft logs and so log only own logs-->
    <logger name="Microsoft.EntityFrameworkCore.*" minlevel="Trace" writeTo="sqllogfile" final="true" />
    <logger name="Microsoft.*" maxlevel="Info" final="true" />

    <!-- Our log -->
    <logger name="*" minlevel="Trace" writeTo="ownFile-web" />
  </rules>
</nlog>

1 Ответ

0 голосов
/ 14 сентября 2018

Перемещение базы данных журнала было ключом. Кроме того, после перемещения журнала регистрации всех сообщений я теперь получаю правильные результаты регистрации.

...