1

我在log4net.config文件中有多个附加程序。我想在发生错误时发送电子邮件。这是我的Log4net.config

 <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
    <file type="log4net.Util.PatternString" value="Logs\${ProcessName}.${InstanceName}.Current.log"/>
    <appendToFile value="true"/>
    <rollingStyle value="Date"/>
    <datePattern value="yyyyMMdd"/>
    <layout type="namespace.CustomPatternLayout, namespace">
        <conversionPattern value="%ProgramId %date [%thread] %-5level %logger [%property{NDC}] - %message%newline"/>
    </layout>
</appender>
<appender name="CustomSmtpAppender" type="namespace.CustomSmtpAppender,namespace">
  <to value="hahm@domain.com"/>
  <from value="hahm@domain.com" />

   <subjectLayout type="log4net.Layout.PatternLayout, log4net">
        <conversionPattern value="Message from Support//%p:%location"/>
    </subjectLayout>
  <smtpHost value="domain" />
  <bufferSize value="1" />
  <authentication value="basic"/>
  <port value="587"/>
  <filter type="log4net.Filter.LevelRangeFilter">
  <levelMin value="ERROR" />
  <levelMax value="OFF" />
  </filter>
  <username value="hahm@domain.com"/>
  <password value=""/>
  <lossy value="true"/>
  <evaluator type="log4net.Core.LevelEvaluator">
      <threshold value="ERROR"/>
   </evaluator>
   <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="Error occur on %date %newline%-5level - %message%newline" />
   </layout>
</appender>
  <logger name="EmailLogger" additivity="false" >
    <level value="ERROR" />
       <appender-ref ref="CustomSmtpAppender" />
  </logger>
  <root>
      <level value="DEBUG" />
    <appender-ref ref="RollingLogFileAppender"/>
    <appender-ref ref="ColoredConsoleAppender"/>
    <appender-ref ref="ConsoleAppender"/>
    <appender-ref ref="FallbackAppender"/>
</root>

所以,我打电话使用:

 LogManager.GetLogger("EmailLogger").Error(ex);

例子:

   catch (Exception ex)
        {
            LogManager.GetLogger("EmailLogger").Error(ex);
            //SaveExceptions.SendExceptionToDB(ex); 
            Console.WriteLine(ex.Message);
            Logger.Error(ex);
            throw;
        }

当有 EmailLogger 描述时,我只想调用“CustomSmtpAppender”

LogManager.GetLogger("EmailLogger").Error(ex);

否则我想在下面描述时调用 RollingLogFileAppender

 _logger = LogManager.GetLogger(this.GetType());

当我运行我的代码时,它总是调用 CustomSmtpAppender。

4

0 回答 0