Log4net用法

2024-01-27 12:18
文章标签 用法 log4net

本文主要是介绍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&quot;.log&quot;" /><!--按照何种方式产生多个日志文件(日期[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&quot;.log&quot;" /><!--按照何种方式产生多个日志文件(日期[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用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/650225

相关文章

SpringBoot UserAgentUtils获取用户浏览器的用法

《SpringBootUserAgentUtils获取用户浏览器的用法》UserAgentUtils是于处理用户代理(User-Agent)字符串的工具类,一般用于解析和处理浏览器、操作系统以及设备... 目录介绍效果图依赖封装客户端工具封装IP工具实体类获取设备信息入库介绍UserAgentUtils

Java中的@SneakyThrows注解用法详解

《Java中的@SneakyThrows注解用法详解》:本文主要介绍Java中的@SneakyThrows注解用法的相关资料,Lombok的@SneakyThrows注解简化了Java方法中的异常... 目录前言一、@SneakyThrows 简介1.1 什么是 Lombok?二、@SneakyThrows

Python中的getopt模块用法小结

《Python中的getopt模块用法小结》getopt.getopt()函数是Python中用于解析命令行参数的标准库函数,该函数可以从命令行中提取选项和参数,并对它们进行处理,本文详细介绍了Pyt... 目录getopt模块介绍getopt.getopt函数的介绍getopt模块的常用用法getopt模

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

Java中Scanner的用法示例小结

《Java中Scanner的用法示例小结》有时候我们在编写代码的时候可能会使用输入和输出,那Java也有自己的输入和输出,今天我们来探究一下,对JavaScanner用法相关知识感兴趣的朋友一起看看吧... 目录前言一 输出二 输入Scanner的使用多组输入三 综合练习:猜数字游戏猜数字前言有时候我们在

java解析jwt中的payload的用法

《java解析jwt中的payload的用法》:本文主要介绍java解析jwt中的payload的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解析jwt中的payload1. 使用 jjwt 库步骤 1:添加依赖步骤 2:解析 JWT2. 使用 N

Linux命令之firewalld的用法

《Linux命令之firewalld的用法》:本文主要介绍Linux命令之firewalld的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux命令之firewalld1、程序包2、启动firewalld3、配置文件4、firewalld规则定义的九大

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程