Bar*_*ens 18 c# log4net-appender
我正在使用log4net来进行日志记录.我希望它同时写入文件和事件日志.
出于某种原因,我在日志文件中找到了两次消息.
这是我的app.config-section:
<log4net>
<root>
<level value="INFO" />
<appender-ref ref="LogFileAppender" />
<appender-ref ref="EventLogAppender" />
</root>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender" >
<param name="File" value="c:\temp\DIS-logfile.txt" />
<param name="AppendToFile" value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="10MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%date %-5level %logger - %message%newline" />
</layout>
</appender>
<appender name="EventLogAppender" type="log4net.Appender.EventLogAppender">
<param name="Indigo.DataIntakeService" value="eventlog" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %-5level %logger - %message%newline" />
</layout>
</appender>
</log4net>
Run Code Online (Sandbox Code Playgroud)
在我的代码中,我有以下内容:
private static readonly ILog Log = log4net.LogManager.GetLogger("DataIntakeService");
private static readonly ILog LogEvents = log4net.LogManager.GetLogger("EventLogAppender");
static void Main(string[] args)
{
log4net.Config.XmlConfigurator.Configure();
}
public static void LogInfo(string message)
{
Log.Info(message);
LogEvents.Info(message);
}
Run Code Online (Sandbox Code Playgroud)
它根据请求写入我的日志文件,但消息也应该发送到我的事件查看器,但这不会发生.它还将这些消息写入日志文件.
我哪里做错了?
Joe*_*Joe 30
您已配置Log4Net,以便根记录器记录到文件和事件日志追加程序.所有记录器都继承此配置,因此您的记录器"DataIntakeService"和"EventLogAppender"都会记录到这些appender.
如果您在事件查看器中看不到日志消息,则可能是因为您的应用程序无权创建事件源.
UPDATE
我如何配置它以便DataIntakeService记录到文件而另一个记录到eventviewer?
这是一个示例配置:
<log4net>
<root>
<level value="INFO" />
<appender-ref ref="LogFileAppender" />
</root>
<logger name="EventLogAppender" additivity="False">
<level value="INFO" />
<appender-ref ref="EventLogAppender" />
</logger>
<appender>
...
Run Code Online (Sandbox Code Playgroud)
有了这个样本:
根记录器(因此除非另外明确配置,否则所有子记录器)将记录到LogFileAppender.您的DataIntakeService记录器未显式配置,因此继承此配置.
该EventLogAppender记录器明确配置为登录EventLogAppender,并配置为不继承父记录器设置(additivity="false").因此它不会登录LogFileAppender.如果设置additivity="true"它将继承设置并记录到两者LogFileAppender和EventLogAppender.
顺便说一句,命名记录器EventLogAppender可能有点令人困惑:EventLogLogger可能是一个更好的名称.
ser*_*lge 11
您可以使用log4net通过以下配置写入不同的记录器.
<log4net>
<logger name="LogFileLogger">
<level value="INFO" />
<appender-ref ref="LogFileAppender" />
</logger>
<logger name="EventLogger">
<level value="INFO" />
<appender-ref ref="EventLogAppender" />
</logger>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
...
</appender>
<appender name="EventLogAppender" type="log4net.Appender.EventLogAppender">
...
</appender>
Run Code Online (Sandbox Code Playgroud)
您可以将记录器称为:
private static readonly log4net.ILog LogFileLogger= log4net.LogManager.GetLogger("LogFileLogger");
private static readonly log4net.ILog EventLogger= log4net.LogManager.GetLogger("EventLogger");
Run Code Online (Sandbox Code Playgroud)