我在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。