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


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

查看所有标签

猜你喜欢:

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

新媒体运营实战技能

新媒体运营实战技能

张向南 勾俊伟 / 人民邮电出版社 / 2017-5 / 39.80元

《新媒体运营实战技能》共7章。第1章重点介绍了新媒体图片的创意思路及制作技巧,包括微信公众号封面图、信息长图、icon图标、九宫图、gif图片的具体实战操作;第2章重点介绍了创意云文字、微信排版、滑动看图等新媒体文字的排版方法与处理技巧;第3章是新媒体表单,引导读者对表单结构、设计场景及具体应用全面了解;第4章关于H5的创意思路及制作方法,解析了引发H5传播的心理因素,并重点介绍H5的制作工具与具......一起来看看 《新媒体运营实战技能》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具