使用log4net写入不同的记录器
我正在使用log4net来进行日志记录。 我希望它同时写入文件和事件日志。
出于某种原因,我在日志文件中找到了两次消息。
这是我的app.config-section:
在我的代码中,我有以下内容:
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); }
它根据请求写入我的日志文件,但消息也应该发送到我的事件查看器,但这不会发生。 它还将这些消息写入日志文件。
我哪里做错了?
您已配置Log4Net,以便根记录器记录到文件和事件日志追加程序。 所有记录器都inheritance此配置,因此您的记录器“DataIntakeService”和“EventLogAppender”都会记录到这些appender。
如果您在事件查看器中看不到日志消息,可能是因为您的应用程序无权创建事件源。
UPDATE
我如何配置它以便DataIntakeService记录到文件而另一个记录到eventviewer?
这是一个示例配置:
...
有了这个样本:
-
根记录器(因此除非另外明确配置,否则所有子记录器)将记录到
LogFileAppender
。 您的DataIntakeService
记录器未显式配置,因此inheritance此配置。 -
EventLogAppender
记录器显式配置为记录到EventLogAppender
,并配置为不从父记录器inheritance设置(additivity="false"
)。 因此,它不会记录到LogFileAppender
。 如果设置additivity="true"
,它将inheritance设置并记录到LogFileAppender
和EventLogAppender
。
顺便说一句,命名记录器EventLogAppender
可能有点令人困惑: EventLogLogger
可能是一个更好的名称。
您可以使用log4net通过以下配置写入不同的记录器。
... ...
您可以将记录器称为:
private static readonly log4net.ILog LogFileLogger= log4net.LogManager.GetLogger("LogFileLogger"); private static readonly log4net.ILog EventLogger= log4net.LogManager.GetLogger("EventLogger");