Ведение журнала корпоративной библиотеки без регистрации в журнале событий из ASP.NET - PullRequest
12 голосов
/ 03 июня 2010

Я провел день, пытаясь заставить Ent Lib Logging работать и регистрировать что-либо в базе данных или журнале событий. У меня есть веб-приложение и консольное приложение с той же конфигурацией Ent Lib, но только консольное приложение способно войти в журнал событий. Я попробовал все с разрешениями, но я не знаю, что именно я делаю & mdash; какие услуги должны иметь что. Не работает!

Я читаю подобные статьи http://imar.spaanjaars.com/275/logging-errors-to-the-event-log-in-aspnet-applications и я хочу попытаться дать учетной записи ASPNET эти разрешения. Я использую Windows 7 и не могу найти учетную запись пользователя ASPNET. Так где это?

Это конфигурационный файл, который автоматически генерируется утилитой Ent Lib и работает только в App.config, а не в web.config

<loggingConfiguration name="Logging Application Block" tracingEnabled="true"
    defaultCategory="General" logWarningsWhenNoCategoriesMatch="true"
    revertImpersonation="false">
    <listeners>
      <add source="Logger" formatter="Text Formatter" log="Application"
        machineName="" 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" />
    </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="Text Formatter" />
    </formatters>
    <categorySources>
      <add switchValue="All" name="General">
        <listeners>
          <add name="Formatted EventLog TraceListener" />
        </listeners>
      </add>
    </categorySources>
    <specialSources>
      <allEvents switchValue="All" name="All Events" />
      <notProcessed switchValue="All" name="Unprocessed Category" />
      <errors switchValue="All" name="Logging Errors &amp; Warnings">
        <listeners>
          <add name="Formatted EventLog TraceListener" />
        </listeners>
      </errors>
    </specialSources>
  </loggingConfiguration>

Ответы [ 4 ]

4 голосов
/ 11 августа 2010

Я использую скрипт PowerShell для создания соответствующего источника ...

$source = "FoToIaW"
if ([System.Diagnostics.EventLog]::SourceExists($source) -eq $false) 
{
  [System.Diagnostics.EventLog]::CreateEventSource($source, "Application")
}
4 голосов
/ 03 июня 2010

Я полагаю, что в IIS7 (который, как я предполагаю, вы используете) пул приложений будет работать под NETWORK SERVICE .

Вы можете попробовать дать NETWORK SERVICE полный доступ к ключу реестра HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application.
(Не рекомендуется!)

В качестве альтернативы, вы можете предоставить КАЖДОМУ Полному контролю HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application, зарегистрировать сообщение, а затем отменить это изменение. После настройки ключа вам не понадобятся разрешения для записи в реестр.

Или вы можете вручную настроить необходимые ключи реестра, чтобы избежать проблем с разрешениями:

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application\Logger]
"EventMessageFile"="c:\\WINNT\\Microsoft.NET\\Framework\\v2.0.50727\\EventLogMessages.dll"


Просто обновление этого ответа в соответствии с MSDN : «Чтобы создать источник событий в Windows Vista и более поздних версиях или Windows Server 2003, у вас должны быть права администратора».

2 голосов
/ 11 декабря 2012

запуск Visual Studio от имени администратора

  1. Щелкните правой кнопкой мыши визуальный значок студии
  2. Нажмите «Запуск от имени администратора»
1 голос
/ 12 января 2011

или используйте этот код ....

 public static void RunSnippet(string logName, string eventSource)
{
    // this will throw an exception if you don't have admin rights
    if (!EventLog.SourceExists(eventSource))
    {
        System.Diagnostics.EventLog.CreateEventSource(eventSource, logName);
        Console.WriteLine("Event Log and Source: {0},{1} were created successfully.",logName, eventSource);
    }
    else
    {
        Console.WriteLine("Event log/source: {0}/{1} already exists",logName, eventSource);
    }
    Console.WriteLine("Done");

}
...