本文主要是介绍Log4net用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Log4net用法
日记是我们在程序中经常用到的,故记于此
首先要下载Log4net.dll
官方网站:http://logging.apache.org/log4net/
vs里创建一个c#控制台程序,在App.config里设置
这里设置的目的,有两个,一为了得到log4net.config的文件,另一个就是日记的开关,日记是否开启
现在看主函数里怎么用
using log4net.Config;
using log4net;namespace Test {class Program {static void Main(string[] args) {//初始化日志文件 string state = ConfigurationManager.AppSettings["IsWriteLog"];//判断是否开启日志记录if (state == "1") {var path = AppDomain.CurrentDomain.SetupInformation.ApplicationBase +ConfigurationManager.AppSettings["log4net"];var fi = new System.IO.FileInfo(path);log4net.Config.XmlConfigurator.Configure(fi);}LogHelper.WriteLog("holle world");}}
}
然后就是LogHelper类了,这个是个简单的日记帮助类
/// <summary> /// LogHelper的摘要说明。 /// </summary> public class LogHelper {/// <summary>/// 静态只读实体对象info信息/// </summary>public static readonly log4net.ILog Loginfo = log4net.LogManager.GetLogger("loginfo");/// <summary>/// 静态只读实体对象error信息/// </summary>public static readonly log4net.ILog Logerror = log4net.LogManager.GetLogger("logerror");/// <summary>/// 添加info信息/// </summary>/// <param name="info">自定义日志内容说明</param>public static void WriteLog(string info) {try {if (Loginfo.IsInfoEnabled) {Loginfo.Info(info);}} catch { }}/// <summary>/// 添加异常信息/// </summary>/// <param name="info">自定义日志内容说明</param>/// <param name="ex">异常信息</param>public static void WriteLog(string info, Exception ex) {try {if (Logerror.IsErrorEnabled) {Logerror.Error(info, ex);}} catch { }}}
最后是log4net.config设置文件
<?xml version="1.0" encoding="utf-8" ?>
<configuration><configSections><section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" /></configSections><log4net><logger name="logerror"><level value="ERROR" /><appender-ref ref="ErrorAppender" /></logger><logger name="loginfo"><level value="INFO" /><appender-ref ref="InfoAppender" /></logger><appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender"><!--设置日志存储路径--><param name="File" value="Data//WebLog//LogError//" /><!--是否追加到文件--><param name="AppendToFile" value="true" /><!--最多产生的日志文件数,超过则只保留最新的n个。设定值value="-1"为不限文件数--><param name="MaxSizeRollBackups" value="100" /><param name="MaxFileSize" value="1024" /><!--是否只写到一个文件中--><param name="StaticLogFileName" value="false" /><!--这是按日期产生文件夹,并在文件名前也加上日期--><param name="DatePattern" value="yyyyMM/dd".log"" /><!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])--><param name="RollingStyle" value="Date" /><layout type="log4net.Layout.PatternLayout"><param name="ConversionPattern" value="%n异常时间:%d [%t] %n异常级别:%-5p %n异常位置:[%thread] (%file:%line) %n消息描述:%message%n异常:%exception%n%n " /></layout></appender><appender name="InfoAppender" type="log4net.Appender.RollingFileAppender"><!--设置日志存储路径--><param name="File" value="Data//WebLog//LogInfo//" /><!--是否追加到文件--><param name="AppendToFile" value="true" /><!--最多产生的日志文件数,超过则只保留最新的n个。设定值value="-1"为不限文件数--><param name="MaxSizeRollBackups" value="100" /><param name="MaxFileSize" value="1024" /><!--是否只写到一个文件中--><param name="StaticLogFileName" value="false" /><!--这是按日期产生文件夹,并在文件名前也加上日期--><param name="DatePattern" value="yyyyMM/dd".log"" /><!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])--><param name="RollingStyle" value="Date" /><layout type="log4net.Layout.PatternLayout"><param name="ConversionPattern" value="%n日志时间:%d [%t] %n日志级别:%-5p %n消息描述:%c [%x] %n%m %n " /></layout></appender></log4net>
</configuration>
level(级别):标识这条日志信息的重要级别。None>Fatal>ERROR>WARN>INFO>DEBUG>ALL,设定一个Level,那么低于这个Level的日志是不会被写到Appender中的。
如果设定了LevelMax和LevelMin则是范围。
// log4j定义了8个级别的log(除去OFF和ALL,可以说分为6个级别),优先级从高到低依次为:OFF、FATAL、ERROR、WARN、INFO、DEBUG、TRACE、 ALL。
//ALL 最低等级的,用于打开所有日志记录。
//DEBUG 指出细粒度信息事件对调试应用程序是非常有帮助的,主要用于开发过程中打印一些运行信息。
//INFO 消息在粗粒度级别上突出强调应用程序的运行过程。打印一些你感兴趣的或者重要的信息,这个可以用于生产环境中输出程序运行的一些重要信息,
//WARN 表明会出现潜在错误的情形,有些信息不是错误信息,但是也要给程序员的一些提示。
//ERROR 指出虽然发生错误事件,但仍然不影响系统的继续运行。打印错误和异常信息,如果不想输出太多的日志,可以使用这个级别。
//FATAL 指出每个严重的错误事件将会导致应用程序的退出。这个级别比较高了。重大错误,这种级别你可以直接停止程序了。
//TRACE designates finer-grained informational events than the DEBUG.Since:1.2.12,很低的日志级别,一般不会使用。
//OFF 最高等级的,用于关闭所有日志记录。
//如果将log level设置在某一个级别上,那么比此级别优先级高的log都能打印出来。例如,如果设置优先级为WARN,那么OFF、FATAL、ERROR、WARN 4个级别的log能正常输出,而INFO、DEBUG、TRACE、 ALL级别的log则会被忽略。Log4j建议只使用四个级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG。
这篇关于Log4net用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!