初次由java转做c#项目,研究了一下log4net的使用。
1. 首先从apache网站下载log4net, http://logging.apache.org/log4net/download_log4net.cgi 。我下的是最新版本 log4net-1.2.11-bin-newkey
2. 将 \bin\net\4.0\release\log4net.dll 复制到你的项目中 。
3. 将log4net.dll 添加引用到你的项目中。
4. 添加如下内容到 assemblyinfo.cs。
- [assembly: log4net.Config.XmlConfigurator(ConfigFile="Log4Net.config", Watch=true)]
注意: ConfigFile 可以指定相对路径 和 绝对路径。 eg: /log/xxxx.log 或者 d://log//xxxx.log
5.在项目中创建一个新的log4net的配置文件Log4Net.config。
- <?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
<!--配置一个结点 名称为log4net-->
</configSections>
<!-- 添加log4net配置节点-->
<log4net debug="true">
<root>
<!--控制级别,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF-->
<!--比如定义级别为INFO,则INFO级别向下的级别,比如DEBUG日志将不会被记录-->
<!--如果没有定义LEVEL的值,则缺省为DEBUG-->
<level value="DEBUG" />
<appender-ref ref="RollingLogFileAppender" />
</root>
<!--定义的是日志记录到文件的附着器 name表示该附着器的名称-->
<!--在log4net中还有一个附着器RollingFileAppender 它表示会循环生成很多文件,举例来说,就是设置一共可以生成20个文件,每个文件的大小为2K,那么如果第一个文件的大小超过2K,就会自动创建一个按顺序命名的文件-->
<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
<!--日志记录的存在路径-->
<!--file可以指定具体的路径 eg : d:\\test.log。不指定的话log被生成在项目的bin/Debug 或者 bin/Release目录下 (web的项目 默认生成在根目录下)-->
<file value="applicationLog.log" />
<!--多线程时采用最小锁定-->
<lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
<!--为true就表示日志会附加到文件,为false,则会重新创建一个新文件-->
<appendToFile value="true" />
<!--日期的格式,每天换一个文件记录,如不设置则永远只记录一天的日志,需设置-->
<!--<datePattern value="(yyyyMMdd)"/> -->
<!--变换的形式为日期,这种情况下每天只有一个日志-->
<!--此时MaxSizeRollBackups和maximumFileSize的节点设置没有意义-->
<!--<rollingStyle value="Date"/>-->
<rollingStyle value="Size" />
<!--每天记录的日志文件个数,与maximumFileSize配合使用-->
<!--备份log文件的个数最多10个-->
<maxSizeRollBackups value="10" />
<!--每个log文件最大是2M,如果超过2M将重新创建一个新的log文件,并将原来的log文件备份。-->
<!--可用的单位:KB|MB|GB-->
<!--不要使用小数,否则会一直写入当前日志-->
<maximumFileSize value="2MB" />
<staticLogFileName value="true" />
<!--指定log的格式-->
<layout type="log4net.Layout.PatternLayout">
<!--输出内容控制-->
<conversionPattern value="[%date] %thread -- %-5level -- %logger [%M] -- %message%newline" />
</layout>
</appender>
</log4net>
</configuration>
注意:根据第4步的配置,应该把log4net的配置文件放到项目的bin/Debug 或者 bin/Release目录下,否则会出现找不到配置文件而无法创建logger对象。
(web的项目,直接放在web项目的根目录下即可)
其中layout节点的配置说明:
%m(message):输出的日志消息;
%n(newline):换行;
%d(datetime):输出当前语句运行的时刻;
%r(runtime):输出程序从运行到执行到当前语句时消耗的毫秒数;
%t(threadid):当前语句所在的线程ID ;
%p(priority): 日志的当前日志级别;
%c(class):当前日志对象的名称;
%L:输出语句所在的行号;
%F:输出语句所在的文件名;
%-10:表示最小长度为10,如果不够,则用空格填充;
6. 然后代码如下:
- using System;
- using System.Reflection;
- using log4net;
- using log4net.Config;
- namespace Log4Net1001
- {
- class Program
- {
- static void Main(string[] args)
- {
- Console.WriteLine("Begin Run");
- XmlConfigurator.Configure();
- Type type = MethodBase.GetCurrentMethod().DeclaringType;
- ILog m_log = LogManager.GetLogger(type);
- m_log.Debug("这是一个Debug日志");
- m_log.Info("这是一个Info日志");
- m_log.Warn("这是一个Warn日志");
- m_log.Error("这是一个Error日志");
- m_log.Fatal("这是一个Fatal日志");
- Console.WriteLine("End");
- Console.ReadLine();
- }
- }
- }
7. 运行你的项目,打出的log结果
- [2012-06-26 14:14:34,862] 1 -- DEBUG -- LogTest.Program [Main] -- this is the log4net log test.
- [2012-06-26 14:14:34,877] 1 -- INFO -- LogTest.Program [Main] -- this is the info..........................................
- [2012-06-26 14:14:34,878] 1 -- INFO -- LogTest.Program [print] -- this method is print()
- [2012-06-26 14:14:34,878] 1 -- ERROR -- LogTest.Program [print] -- error test