c# log组件 log4net使用介绍
2016-04-05 10:19
281 查看
在软件开发和测试过程中,打印log信息是必不可少的调试方法。尤其在定位偶发性出现的问题的时候,用log的方式,就能体现出优势了。 log4net是一个开源的log代码,只需要应用他的dll,并且在config中进行相关配置,就能在程序中轻松使用了。 log4net 下载地址: http://logging.apache.org/log4net/download_log4net.cgi 下载后 就有log4net.dll。 配置方法如下: 1: 引用 log4net.dll 2: 在app.config 中插入如下代码 注意: configSections 必须放在<configSection> 后的第一个位置
<configSections> <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net-net-1.0"/> </configSections> <!--站点日志配置部分--> <log4net> <root> <!--控制级别,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF--> <!--比如定义级别为INFO,则INFO级别向下的级别,比如DEBUG日志将不会被记录--> <!--如果没有定义LEVEL的值,则缺省为DEBUG--> <level value="ALL"/> <appender-ref ref="RollingFileAppender"/> </root> <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender"> <!--日志文件名开头--> <file value="Log\\TestLog4net.txt"/> <!--多线程时采用最小锁定--> <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/> <!--日期的格式,每天换一个文件记录,如不设置则永远只记录一天的日志,需设置--> <datePattern value="(yyyyMMdd)"/> <!--是否追加到文件,默认为true,通常无需设置--> <appendToFile value="true"/> <!--变换的形式为日期,这种情况下每天只有一个日志--> <!--此时MaxSizeRollBackups和maximumFileSize的节点设置没有意义--> <!--<rollingStyle value="Date"/>--> <!--变换的形式为日志大小--> <!--这种情况下MaxSizeRollBackups和maximumFileSize的节点设置才有意义--> <RollingStyle value="Size"/> <!--每天记录的日志文件个数,与maximumFileSize配合使用--> <MaxSizeRollBackups value="10"/> <!--每个日志文件的最大大小--> <!--可用的单位:KB|MB|GB--> <!--不要使用小数,否则会一直写入当前日志--> <maximumFileSize value="100MB"/> <!--日志格式--> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%t]%p: %m%n"/> </layout> </appender> </log4net>
3:在 assemblyinfo.cs中增加 [assembly: log4net.Config.DOMConfigurator(ConfigFileExtension = "config", Watch = true)] c#代码如下
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using log4net; using log4net.Config; namespace InvokeCpp { class LogTest { public void print() { ILog m_log = LogManager.GetLogger("log"); m_log.Debug("这是一个Debug日志"+2); m_log.Info("这是一个Info日志"); m_log.Warn("这是一个Warn日志"); m_log.Error("这是一个Error日志"); m_log.Fatal("这是一个Fatal日志"); } } class Program { static void Main(string[] args) { LogTest log = new LogTest(); log.print(); } } }
在Testlog4net.txt中就有
2016-04-05 10:01:08,085 [8]DEBUG 这是一个Debug日志 %d2
2016-04-05 10:01:08,096 [8]INFO 这是一个Info日志
2016-04-05 10:01:08,099 [8]WARN 这是一个Warn日志
2016-04-05 10:01:08,102 [8]ERROR 这是一个Error日志
2016-04-05 10:01:08,104 [8]FATAL 这是一个Fatal日志
其中layout节点的配置说明:
%m(message):输出的日志消息;
%n(newline):换行;
%d(datetime):输出当前语句运行的时刻;
%r(runtime):输出程序从运行到执行到当前语句时消耗的毫秒数;
%t(threadid):当前语句所在的线程ID ;
%p(priority): 日志的当前日志级别;
%c(class):当前日志对象的名称;
%L:输出语句所在的行号;
%F:输出语句所在的文件名;
%-10:表示最小长度为10,如果不够,则用空格填充;
其他注意事项: 来自 /article/8266320.html
1.项目的目标框架为.NET Framework 3.5(或者4) Client Profile时会报出下图错误,改成.NET Framework 3.5(或者4) 即可;
2.当configSections节点没有放在configuration节点下的第一个节点时,编译时不会报警告,但运行时不会记日志。这是因为自定义的节点configSections这个必须放在第一个,这是app.config文件的语法规定; 3.对于大量记日志的程序,需注意配置RollingStyle值为Composite,且设置MaxSizeRollBackups(每天记录的日志文件个数)和maximumFileSize(每个日志文件的最大大小)。我以前遇过一次日志过大的问题,有一次版本临时发布就改了一个方法而没有经过测试,造成每天记几十G日志的,几天就把服务器磁盘弄满了。 4.当发现不记日志时,可从两方面调查问题,一是log4net有没有初始化,也就是XmlConfigurator.Configure();二是看level节点的配置是不是正确; 5.当发现一些设置参数没有起作用时,请检查是不是同一个节点被设置过多次,当被重复设置时,log4net会选择最后一个作为实际的设置。例如设置记录日志的级别设置两次如<level value="ERROR"/><level value="All"/>,则最终会以ALL作为记录日志的级别。 6.如果是网站项目,须在项目中的AssemblyInfo.cs文件的最后一行中添加:
[assembly: log4net.Config.DOMConfigurator(ConfigFile = "Web.config", Watch = true)]
相关文章推荐
- C# 利用ICSharpCode.SharpZipLib实现在线压缩和解压缩
- leetcode 3 : Longest Substring Without Repeating Characters 最长无重复子串 (C# 语言版)
- C# The process cannot access the file because it is being used by another process
- 基于C# 生成Zip压缩包代码
- C# 操作INI配置文件
- C# Distinct使用,支持对象的相等比较
- vs2015中 c#如何 编译成低版本供xp使用
- C#16位MD5加密算法
- C#流(stream)
- .Net/C# 实现 中国移动 CMPP v3.0 ISMG <-> SP 收发短信的 SP 客户端 (CMPP SP Client)
- C#多线程网页采集器(Spider)
- C#实现的ReplaceFirst和ReplaceLast
- C# winform程序怎么打包成安装项目(图解)
- C#Winform程序如何发布并自动升级(图解)
- c#怎么分析网页的DOM?
- C#读取INI文件
- C#面向对象整理
- C#(近期目标)
- <C#入门经典>学习笔记3之类型转换与枚举
- 【C#】万事开头难(三)<机房重构>