详解log4net的使用
程序中只需要引用log4net.dll文件即可
配置的引用
log4net.config.xmlconfigurator.configure();
首先添加以上代码。
cs程序:在main方法中添加;
bs程序:application_start方法中添加;
或是两者都可以在assemblyinfo.cs(properties中)文件里添加以下的语句:
//设置独立配置文件,log4net.config [assembly: log4net.config.xmlconfigurator(configfile = "log4net.config" , watch = true )] //或是默认的配置文件 [assembly: log4net.config.xmlconfigurator(watch = true )] (配置在web.config文件中)
详细配置
log4net,可以把日志输出到控制台程序,文件,数据库、邮件,下面贴出四个输出的配置代码,其余如window日志等输出不做阐述。
<?xml version="1.0" encoding="utf-8" ?> <configuration> <!--首先加入configsections配置节点--> <configsections> <section name="log4net" type="log4net.config.log4netconfigurationsectionhandler,log4net"/> </configsections> <log4net><br> <root> <!--(高) off > fatal > error > warn > info > debug > all (低) --> <!--限制日志记录级别--> <level value="all" /> <!--将日志输出到文件--> <appender-ref ref="fileappender"/> <!--将日志输出到应用程序控制台--> <appender-ref ref="consoleappender"/> <!--将日志写到邮件中--> <!--<appender-ref ref="logsmtpappender"/>--> <!--将日志记录到数据库中。可以采用sql和存储过程两种方式--> <appender-ref ref="adonetappender"/> <!--可以同时设置多个输出对象,没用到可以注释--> <!--将日志写到local syslog service (仅用于unix环境下)。--> <!--<appender-ref ref="localsyslogappender"/>--> </root><br> <!--发邮件--> <appender name="logsmtpappender" type="log4net.appender.smtpappender"> <authentication value="basic" /> <!--接受邮件的邮箱--> <to value="7778888@qq.com" /> <!--发送邮件的邮箱--> <from value="123456@126.com" /> <!--发送邮件的邮箱--> <username value="123456@126.com" /> <!--发送邮件的邮箱密码--> <password value="123456" /> <!--标题--> <subject value="xxx应用错误日志消息" /> <!--smtp.qq.com--> <smtphost value="smtp.126.com" /> <buffersize value="2048" /> <!--超长部分是否丢弃--> <lossy value="true" /> <!--日志级别 大于 warn 的才发邮件--> <evaluator type="log4net.core.levelevaluator"> <threshold value="error"/> </evaluator> <layout type="log4net.layout.patternlayout"> <conversionpattern value=" %level :: %message %newlinelogger: %logger%newline date: %date%newline" /> </layout> </appender><br> <!-- 控制台日志 --> <appender name="consoleappender" type="log4net.appender.consoleappender"> <layout type="log4net.layout.patternlayout"> <conversionpattern value="%n%d{yyyy-mm-dd hh:mm:ss} %m%n" /> </layout> <!--指定范围内的等级才可以被记录--> <!--<filter type="log4net.filter.levelrangefilter"> <param name="levelmin" value="info" /> <param name="levelmax" value="fatal" /> </filter>--> </appender > <!--指定日记记录方式,以滚动文件的方式(文件记录)--> <appender name="fileappender" type="log4net.appender.rollingfileappender"> <!--日志路径--> <param name= "file" value= "log/"/> <!--是否是向文件中追加日志--> <param name= "appendtofile" value= "true"/> <!--log保留天数--> <param name= "maxsizerollbackups" value= "10"/> <!--每个文件最大1m--> <param name="maximumfilesize" value="1mb" /> <!--日志文件名是否是固定不变的--> <param name= "staticlogfilename" value= "false"/> <!--日志文件名格式为:2008-08-31.log--> <param name= "datepattern" value= "yyyy-mm-dd".log""/> <!--日志根据日期滚动--> <param name= "rollingstyle" value= "date"/> <!--布局--> <layout type="log4net.layout.patternlayout"> <param name="conversionpattern" value="%n记录时间:%d{yyyy-mm-dd hh:mm:ss} 线程名:[%t] 级别:%p 类名:%c 信息:%m%n" /> <param name="header" value="----------------------------------------------------------- "/> </layout> </appender><br> <!--数据库日记--> <appender name="adonetappender" type="log4net.appender.adonetappender"> <!--设置为1方便查看结果,处于性能考虑这里的值应该略大一点,官方默认值是100,buffersize为缓冲区大小,只有日志记录超设定值才会一块写入到数据库--> <buffersize value="1" /> <!--sqlserver 引用--> <connectiontype value="system.data.sqlclient.sqlconnection, system.data, version=1.0.3300.0, culture=neutral, publickeytoken=b77a5c561934e089" /> <!--连接数据库字符串--> <connectionstring value="data source=.;initial catalog=test;integrated security=false;persist security info=true;user id=sa;password=sqlserver;" /> <!--插入到表log--> <commandtext value="insert into logtest ([date],[level],[logger],[message],[exception],[description],[objtype]) values (@log_date,@log_level, @logger, @message, @exception,@description,@objtype)" /> <!--所有参数--> <parameter> <parametername value="@log_date" /> <dbtype value="datetime" /> <layout type="log4net.layout.rawtimestamplayout" /> </parameter> <parameter> <parametername value="@log_level" /> <dbtype value="string" /> <size value="50" /> <layout type="log4net.layout.patternlayout"> <conversionpattern value="%level" /> </layout> </parameter> <!--类所在位置--> <parameter> <parametername value="@logger" /> <dbtype value="string" /> <size value="255" /> <layout type="log4net.layout.patternlayout"> <conversionpattern value="%logger" /> </layout> </parameter> <parameter> <parametername value="@message" /> <dbtype value="string" /> <size value="4000" /> <layout type="log4net.layout.patternlayout"> <conversionpattern value="%message" /> </layout> </parameter> <parameter> <parametername value="@exception" /> <dbtype value="string" /> <size value="2000" /> <layout type="log4net.layout.exceptionlayout" /> </parameter> <!--自定义输入字段--> <parameter> <parametername value = "@description"/> <dbtype value = "string"/> <size value = "50"/> <layout type = "log4_test.log4netexpand.expandlayout"> <conversionpattern value = "%property{description}"/> </layout> </parameter> <parameter> <parametername value = "@objtype"/> <dbtype value = "string"/> <size value = "50"/> <layout type = "log4_test.log4netexpand.expandlayout"> <conversionpattern value = "%property{objtype}"/> </layout> </parameter> </appender> </log4net> </configuration>
<layout type = "log4_test.log4netexpand.expandlayout"> 中的log4_test.log4netexpand 为命名空间
布局、格式字符说明:
%p:输出日志信息的优先级,即debug,info,warn,error,fatal。
%d:输出日志时间点的日期或时间,默认格式为iso8601,也可以在其后指定格式,如:%d{yyyy/mm/dd hh:mm:ss,sss}。
%r:输出自应用程序启动到输出该log信息耗费的毫秒数。
%t:输出产生该日志事件的线程名。
%l:输出日志事件的发生位置,相当于%c.%m(%f:%l)的组合,包括类全名、方法、文件名以及在代码中的行数。例如:test.testlog4j.main(testlog4j.java:10)。
%c:输出日志信息所属的类目,通常就是所在类的全名。
%m:输出产生日志信息的方法名。
%f:输出日志消息产生时所在的文件名称。
%l::输出代码中的行号。
%m::输出代码中指定的具体日志信息。
%n:输出一个回车换行符,windows平台为"\r\n",unix平台为"\n"。
%x:输出和当前线程相关联的ndc(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。
%%:输出一个"%"字符。
另外,还可以在%与格式字符之间加上修饰符来控制其最小长度、最大长度、和文本的对齐方式。如:
1)%20c:指定输出category的名称,最小的长度是20,如果category的名称长度小于20的话,默认的情况下右对齐。
2)%-20c:"-"号表示左对齐。
3)%.30c:指定输出category的名称,最大的长度是30,如果category的名称长度大于30的话,就会将左边多出的字符截掉,但小于30的话也不会补空格。
自定义数据库插入字段(源自网络收集、整理)
1.先定义一个logdata类:
namespace log4_test.log4netexpand { public class logdata { /// <summary> /// 日志描述信息 /// </summary> public string description { get; set; } /// <summary> /// 日志描述信息 /// </summary> public string objtype { get; set; } } }
2.layout扩展类
namespace log4_test.log4netexpand { public class expandlayout : patternlayout { public expandlayout() { this.addconverter("property", typeof(mymessagepatternconverter)); } } }
3.mymessagepatternconverter 类
namespace log4_test.log4netexpand { public class mymessagepatternconverter: patternlayoutconverter { protected override void convert(system.io.textwriter writer, log4net.core.loggingevent loggingevent) { if (option != null) { // write the value for the specified key writeobject(writer, loggingevent.repository, lookupproperty(option, loggingevent)); } else { // write all the key value pairs writedictionary(writer, loggingevent.repository, loggingevent.getproperties()); } } /// <summary> /// 通过反射获取传入的日志对象的某个属性的值 /// </summary> /// <param name="property"></param> /// <returns></returns> private object lookupproperty(string property, log4net.core.loggingevent loggingevent) { object propertyvalue = string.empty; propertyinfo propertyinfo = loggingevent.messageobject.gettype().getproperty(property); if (propertyinfo != null) { propertyvalue = propertyinfo.getvalue(loggingevent.messageobject, null); } return propertyvalue; } } }
4.使用代码如下:
public class program { static void main(string[] args) { //能看到是那个类输出 ilog logger = log4net.logmanager.getlogger(typeof(program)); logger.info(new logdata { description="123", objtype="123"}) logger.info("消息11111111111111111111111111111"); logger.warn("警告"); logger.error("异常"); logger.fatal("错误"); } }
以上所述是小编给大家介绍的log4net的使用详解整合,希望对大家有所帮助