Enterprise Library Logging 4.1 не записывает в прослушиватель ошибок, когда файл недоступен - PullRequest
4 голосов
/ 08 июля 2010

Мы настроили ведение журнала Enterprise Library 4.1 для записи в журнал событий при сбое обычной регистрации.Это прекрасно работает, когда ведение журнала настроено неправильно (например, недопустимый символ в атрибуте слушателя fileName), но ничего не записывается в журнал событий, когда в настроенный файл невозможно записать из-за недопустимых разрешений.

FWIW вот файл конфигурации:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="loggingConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.LoggingSettings, Microsoft.Practices.EnterpriseLibrary.Logging, Version=4.1.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" />
  </configSections>
  <loggingConfiguration name="Logging Application Block" tracingEnabled="true" defaultCategory="General" logWarningsWhenNoCategoriesMatch="true">
    <listeners>
      <add source="Enterprise Library Logging" formatter="Event Log Formatter" machineName="."
           log="Application"
           listenerDataType="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.FormattedEventLogTraceListenerData, Microsoft.Practices.EnterpriseLibrary.Logging, Version=4.1.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
           traceOutputOptions="None" filter="All"
           type="Microsoft.Practices.EnterpriseLibrary.Logging.TraceListeners.FormattedEventLogTraceListener, Microsoft.Practices.EnterpriseLibrary.Logging, Version=4.1.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
           name="Formatted EventLog TraceListener" />
      <add formatter="Text Formatter"
        fileName="d:\trace.log" listenerDataType="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.RollingFlatFileTraceListenerData, Microsoft.Practices.EnterpriseLibrary.Logging, Version=4.1.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
        traceOutputOptions="None" filter="All" type="Microsoft.Practices.EnterpriseLibrary.Logging.TraceListeners.RollingFlatFileTraceListener, Microsoft.Practices.EnterpriseLibrary.Logging, Version=4.1.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
        name="Text TraceListener" />
    </listeners>
    <formatters>
      <add template="Timestamp: {timestamp}&#xD;&#xA;Message: {message}&#xD;&#xA;Category: {category}&#xD;&#xA;Priority: {priority}&#xD;&#xA;EventId: {eventid}&#xD;&#xA;Severity: {severity}&#xD;&#xA;Title:{title}&#xD;&#xA;Machine: {machine}&#xD;&#xA;Application Domain: {appDomain}&#xD;&#xA;Process Id: {processId}&#xD;&#xA;Process Name: {processName}&#xD;&#xA;Win32 Thread Id: {win32ThreadId}&#xD;&#xA;Thread Name: {threadName}&#xD;&#xA;Extended Properties: {dictionary({key} - {value}&#xD;&#xA;)}" type="Microsoft.Practices.EnterpriseLibrary.Logging.Formatters.TextFormatter, Microsoft.Practices.EnterpriseLibrary.Logging, Version=4.1.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" name="Event Log Formatter" />
      <add template="[{timestamp(yyyy-MM-dd HH:mm:ss,fff)}] {severity} {category}: {message}"
        type="Microsoft.Practices.EnterpriseLibrary.Logging.Formatters.TextFormatter, Microsoft.Practices.EnterpriseLibrary.Logging, Version=4.1.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
        name="Text Formatter" />
    </formatters>
    <specialSources>
      <allEvents switchValue="All" name="All Events" />
      <notProcessed switchValue="All" name="Unprocessed Category">
        <listeners>
          <add name="Text TraceListener" />
        </listeners>
      </notProcessed>
      <errors switchValue="All" name="Logging Errors &amp; Warnings">
        <listeners>
          <add name="Formatted EventLog TraceListener" />
        </listeners>
      </errors>
    </specialSources>
  </loggingConfiguration>
</configuration>

Кто-нибудь решил этот вопрос?

1 Ответ

2 голосов
/ 27 июля 2010

Вы упоминаете, что видите такое поведение, когда есть проблемы, связанные с недействительными разрешениями ;хотя никакой конкретной документации по этому поводу нет, - это информация о доступе для чтения / записи к файлу:

Кажется, что проблема в том, что Enterprise Library нене считают невозможным запись в файл журнала, поскольку он доступен только для чтения как ошибка.Это указано в следующей документации от MSDN :

Таблица 4: Свойства TraceListener Flatfile

Примечание:

Если файл, указанный вами для FlatfileTraceListener, предназначен только для чтения, прослушиватель трассировки не записывает данные в файл и исключение не возникает .Убедитесь, что атрибуты файла установлены на чтение / запись.

Поэтому, поскольку он не считает это ошибкой, он не будет обнаружен специальной категорией «Ошибки и предупреждения при ведении журнала»и, следовательно, не будет записан в журнал событий (в вашем случае).

Хотя в документации не указано, что то же самое произойдет для проблем с разрешениями, я устал использовать оба файла конфигурации (только для чтения и без разрешения соответственно) и демонстрируется то же поведение.

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

...