Регистрация в корпоративной библиотеке, не регистрирующаяся в журнале событий из ASP.NET
Я потратил целый день, пытаясь заставить Ent Lib Logging работать и записывать что-либо в базу данных или журнал событий. У меня есть приложение для веб-приложений и консолей с той же конфигурацией Ent Lib, но только консольное приложение может войти в журнал событий. Я пробовал все с разрешениями, но я не знаю, что именно я делаю — какие службы должны иметь что. Это не работает!
Я читаю статьи, подобные этому
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}
Message: {message}
Category: {category}
Priority: {priority}
EventId: {eventid}
Severity: {severity}
Title:{title}
Machine: {machine}
Application Domain: {appDomain}
Process Id: {processId}
Process Name: {processName}
Win32 Thread Id: {win32ThreadId}
Thread Name: {threadName}
Extended Properties: {dictionary({key} - {value}
)}"
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 & Warnings">
<listeners>
<add name="Formatted EventLog TraceListener" />
</listeners>
</errors>
</specialSources>
</loggingConfiguration>
Ответы
Ответ 1
Я считаю, что в рамках IIS7 (который, как я полагаю, вы используете) пул приложений будет запущен под NETWORK SERVICE.
Вы можете попробовать предоставить NETWORK SERVICE полный доступ к разделу реестра HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application
.
(Не рекомендуется!)
В качестве альтернативы вы можете предоставить EVERYONE Full control 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
Я использую PowerShell script для создания соответствующего источника...
$source = "FoToIaW"
if ([System.Diagnostics.EventLog]::SourceExists($source) -eq $false)
{
[System.Diagnostics.EventLog]::CreateEventSource($source, "Application")
}
Ответ 3
запустить визуальную студию как администратор
- Щелкните правой кнопкой мыши значок визуальной студии
- Нажмите "Запуск от имени администратора"
Ответ 4
или используйте этот код....
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");
}