log4net сохранение ошибок в БД, получение нулей в параметрах - PullRequest
1 голос
/ 14 декабря 2011

При вставке строк в БД SQL Server 2005 я получаю нулевые значения в Environment, ApplicationName, ApplicationPath, ExceptionData.

Моя конфигурация log4net следующая:

<log4net>
  <appender name="ADONetAppender_SqlServer" type="log4net.Appender.AdoNetAppender">
  <bufferSize value="1" />
    <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
  <connectionString value="Data Source=xxx;Initial Catalog=xxx;User Id=xxx;Password=xx;Connection Timeout=200;" />
  <commandText value="INSERT INTO [ApplicationLog] ([TimeStamp],[SeverityLevel],[LoggerName],[Environment],[ApplicationName],[ApplicationPath],[ServerName],[Message],[ExceptionData]) VALUES (@TimeStamp,@SeverityLevel,@LoggerName,@Environment,@ApplicationName,@ApplicationPath,@ServerName,@Message,@ExceptionData)" />
    <parameter>
      <parameterName value="@TimeStamp" />
      <dbType value="DateTime" />
      <layout type="log4net.Layout.RawTimeStampLayout" />
    </parameter>
    <parameter>
      <parameterName value="@SeverityLevel" />
      <dbType value="String" />
      <size value="10" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%level" />
      </layout>
    </parameter>
    <parameter>
      <parameterName value="@LoggerName" />
      <dbType value="String" />
      <size value="255" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%logger" />
      </layout>
    </parameter>
    <parameter>
      <parameterName value="@Environment" />
      <dbType value="String" />
      <size value="-1" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%property{EnvironmentName}" />
      </layout>
    </parameter>
    <parameter>
      <parameterName value="@ApplicationName" />
      <dbType value="String" />
      <size value="128" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%property{AppName}" />
      </layout>
    </parameter>
    <parameter>
      <parameterName value="@ApplicationPath" />
      <dbType value="String" />
      <size value="255" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%property{AppPath}" />
      </layout>
    </parameter>
    <parameter>
      <parameterName value="@ServerName" />
      <dbType value="String" />
      <size value="255" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%property{log4net:HostName}" />
      </layout>
    </parameter>
    <parameter>
      <parameterName value="@Message" />
      <dbType value="String" />
      <size value="-1" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%message" />
      </layout>
    </parameter>
    <parameter>
      <parameterName value="@ExceptionData" />
      <dbType value="String" />
      <size value="-1" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%property{exceptionDetails}" />
      </layout>
    </parameter>
</appender>
<appender name="SmtpAppender" type="log4net.Appender.SmtpAppender">
  <to value="xxx" />
  <from value="xxx" />
  <subject value="(Error) xxx" />
  <smtpHost value="xxx" />
  <bufferSize value="1" />
  <lossy value="false" />
  <threshold value="ERROR" />
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%utcdate [%thread] %-5level %logger [%property{log4net:HostName}] - %message%newline%newlineException details:%newline%property{exceptionDetails}" />
  </layout>
</appender>

<root>
  <level value="INFO" />
  <appender-ref ref="ADONetAppender_SqlServer" />
  <appender-ref ref="SmtpAppender" />
</root>

В global.asax, Application_Error, я вызываю log4net для настройки, а затем регистрирую исключение следующим образом:

Dim ex As New Exception
ex = Server.GetLastError      

log4net.Config.XmlConfigurator.Configure()
log.Logger.Log(ex.Source.GetType, log4net.Core.Level.Fatal, ex.StackTrace, ex)

Что я делаю не так?

1 Ответ

1 голос
/ 15 декабря 2011

Поскольку вы явно не сказали иначе или не показали, как вы их инициализируете, я предполагаю, что вы думаете, что Environment, ApplicationName, ApplicationPath и ExceptionData являются предопределенными свойствами, которые я не считаю верными.

Итак, если вы хотите использовать эти свойства, то где-то в вашем коде вам нужно установить эти свойства на нужные вам значения. Например,

 log4net.GlobalContext.Properties["AppName"] = "...";

или

 log4net.ThreadContext.Properties["exceptionDetails] = "...";

Некоторые из переменных могут быть глобальными для вашего приложения и, следовательно, могут быть установлены один раз, но исключения должны быть установлены непосредственно перед вызовом log.Logger.Log и должны использовать ThreadContext, а не GlobalContext.

Смотрите здесь для получения дополнительной информации о различных контекстах

Обратите внимание, есть несколько предопределенных шаблонов , которые вы можете использовать вместо этого. Например% исключение или% appdomain

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...