c# – 使用log4net写入不同的记录器

栏目: ASP.NET · 发布时间: 6年前

内容简介:http://stackoverflow.com/questions/17106559/using-log4net-to-write-to-different-loggers

我正在使用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>

在我的代码中,我需要如下:

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);
        }

它根据请求写入我的日志文件,但是消息也应该去我的eventviewer,而不会发生.它也将这些消息写入日志文件.

我哪里做错了?

您已配置Log4Net,以便根日志记录器同时记录文件和事件日志追加器.

所有记录器都会继承此配置,因此您的记录器“DataIntakeService”和“EventLogAppender”都会记录到这些附录.

如果在事件查看器中看不到日志消息,可能是因为您的应用程序没有创建事件源的权限.

UPDATE

How can i configure it so the DataIntakeService logs to the file and the other one to the 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>
  ...

有了这个例子:

>根记录器(以及所有的子记录器,除非另有明确配置)将记录到LogFileAppender.您的DataIntakeService记录器未显式配置,因此继承此配置.

> EventLogAppender记录器被明确配置为登录到EventLogAppender,并且配置为不继承父记录器中的设置(additivity =“false”).因此,它不会记录到LogFileAppender.如果设置additivity =“true”,它将继承设置并记录到LogFileAppender和EventLogAppender.

顺便提一句,命名一个记录器EventLogAppender可能有点混乱:EventLogLogger可能是一个更好的名字.

http://stackoverflow.com/questions/17106559/using-log4net-to-write-to-different-loggers


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Android和PHP开发最佳实践

Android和PHP开发最佳实践

黄隽实 / 机械工业出版社华章公司 / 2013-3-20 / 79.00元

本书是国内第一本同时讲述Android客户端开发和PHP服务端开发的经典著作。 本书以一个完整的微博应用项目实例为主线,由浅入深地讲解了Android客户端开发和PHP服务端开发的思路和技巧。从前期的产品设计、架构设计,到客户端和服务端的编码实现,再到性能测试和系统优化,以及最后的打包发布,完整地介绍了移动互联网应用开发的过程。同时,本书也介绍了Android系统中比较有特色的功能,比如Go......一起来看看 《Android和PHP开发最佳实践》 这本书的介绍吧!

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具