C# log4net日志库的用法小结
作者:Genven_Liang 发布时间:2023-12-26 18:50:44
一、简述
记--log4net日志开源库的简单使用:控制日志文件大小,日志文件个数,滚动式覆盖,自由控制日志打印等级
例子打包:
http://xiazai.jb51.net/202110/yuanma/Log4netTest_jb51.rar
http://xiazai.jb51.net/202110/yuanma/apache-log4net-source_jb51.rar
http://xiazai.jb51.net/202110/yuanma/apache-log4net-binaries_jb51.rar
二、下载log4net
直接使用log4net源码或直接使用log4net源码编译对应的dll或直接使用log4net.dll
下载地址:http://logging.apache.org/log4net/download_log4net.html
例子直接使用其中4.5的dll。(请根据当前环境的.net framework框架版本进行选择,请看右键项目--》属性--》应用程序--》目标框架)
三、添加log4net.dll引用
四、添加日志配置log.config
编辑log.config内容如下:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<log4net>
<appender name="MyAppender1" type="log4net.Appender.RollingFileAppender">
<file value="app.log" /> <!--日志文件名-->
<appendToFile value="true" /> <!--日志文件以追加方式进行-->
<rollingStyle value="Size" /> <!--按文件大小进行滚动记录,也可以按日期-->
<maxSizeRollBackups value="2" /> <!--最多两个日志备份,app.log.1 app.log.2-->
<maximumFileSize value="8KB" /> <!--日志文件达到8KB就重新记一个文件-->
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<!--每一行日志输出格式-->
<conversionPattern value="%date [%thread] (%file:%line) %-5level %logger - %message%newline" />
</layout>
</appender>
<logger name="Mylog1"> <!--代码通过Mylog1获取对应的logger句柄-->
<level value="WARN" /> <!--比WARN等级低的不会输出 日志等级由高到低:OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL-->
<appender-ref ref="MyAppender1" /> <!--启用MyAppender1-->
</logger>
</log4net>
</configuration>
将配置同步更新到exe输出路径
五、在AssemblyInfo.cs文件中添加log4net.dll相关参数
在AssemblyInfo.cs文件末尾添加一行(其中的log.config就是步骤四添加的配置文件)
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log.config", Watch = true)]
六、测试例子
6.1 测试代码
namespace Log4netTest
{
public partial class Form1 : Form
{
//Mylog1对应log.config种的一个logger名称
public static readonly log4net.ILog mLogger = log4net.LogManager.GetLogger("Mylog1");
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
mLogger.Error("APP Start");
mLogger.Debug("logDebug");
mLogger.Info("logInfo");
mLogger.Warn("logWarn");
mLogger.Error("logError");
mLogger.Error(this);
}
}
注:代码种的Mylog1对应log.config中的一个logger名称
6.2 效果
控制日志文件大小,日志文件个数,滚动式覆盖,控制日志打印等级为WARN。
七、附
7.1 更多日志配置
http://logging.apache.org/log4net/release/manual/configuration.html
7.2 日志格式
%m(message):输出的日志消息,如ILog.Debug(…)输出的一条消息
%n(new line):换行
%d(datetime):输出当前语句运行的时刻
%r(run time):输出程序从运行到执行到当前语句时消耗的毫秒数
%t(thread id):当前语句所在的线程ID
%p(priority): 日志的当前优先级别,即DEBUG、INFO、WARN…等
%c(class):当前日志对象的名称,例如:
%f(file):输出语句所在的文件名。
%l(line):输出语句所在的行号。
%数字:表示该项的最小长度,如果不够,则用空格填充,如“%-5level”表示level的最小宽度是5个字符,如果实际长度不够5个字符则以空格填充
7.3 日志配置
appender、logger标签可多个,不是一一对应关系的
来源:https://blog.csdn.net/nanfeibuyi/article/details/120689401
猜你喜欢
- lambda表达式以及并行流。官方承诺你写出来的代码更运行得更快。流会自动通过Fork/Join池并行地执行。我听过一些关于Java 8的主
- 调用微信接口前需要准备的内容。1.微信公众平台的appid2.微信公众平台的secret3..获取tokenid4.获取ticket5.生成
- (注意:本文基于JDK1.8)前言任何一个容器类对象用于持有元素后,总是需要遍历元素的,即挨个去访问每个元素1次,而遍历元素,除了常规的依赖
- 设置超时时间设置HttpClient的超时时间,非常有必要性,因为httpclient 默认超时时间很长,自己可以测试一下是多久,设置超时时
- WebBrowser是C#中非常实用的一个控件,本文以实例形式分析了WebBrowser的用法,供大家参考。具体分析如下:一、WebBrow
- Spring Boot如何实现分布式锁的自动释放在分布式系统中,为了保证数据的一致性和可靠性,常常需要使用分布式锁。在实际开发中,我们可以使
- 快速排序使用分治法(Divide and conquer)策略来把一个串行(list)分为两个子串行(sub-lists)。步骤为:1.从数
- 这篇文章主要介绍了JavaMail与Spring整合过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需
- 一般我们在controller层调用service时,只需要使用@Autowired注解即可,例如如下代码我们经常看到:@RestContr
- Map接口Map类似y(x)=x;这样的函数(key对应x,value对应y)Map与Collection并列存在。用于保存具有映射关系的数
- 本文实例为大家分享了Android弹窗控件CustomFiltControl的使用方法,供大家参考,具体内容如下效果:起初踩的坑:&nbs
- 题目我们可以用2×1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2×1的小矩形无重叠地覆盖一个2×n的大矩形,总共有多少种方法?程序核心
- RecyclerView显示Item布局不一致在自定义RecyclerAdapter的时候,在重写onCreateViewHolder方法是
- 什么是slf4jSLF4J,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务
- C#处理猜拳问题的简单实例(非窗体)//猜拳,5局3胜,要求使用公用变量。namespace 结构体复习_公用变量{class Progra
- Spring Cloud是一个基于Spring Boot实现的云应用开发工具,它为基于JVM的云应用开发中的配置管理、服务发现、断路器、智能
- 什么是事务处理事务是计算机应用中不可或缺的组件模型,它保证了用户操作的原子性 ( Atomicity )、一致性 ( Consistency
- 委托是一个类,它定义了方法的类型,使得可以将方法当作另一个方法的参数来进行传递,这种将方法动态地赋给参数的做法,可以避免在程序中大量使用If
- AspectJ 是通过注解来描述切点与增强的。1 开发环境要求因为要使用注解,所以请确保使用的 Java5.0 及以上版本。引入 Aspec
- 第一篇讲了文件的基本概念,和文件如何打开和关闭。第二篇主要介绍文件的顺序读写和随机读写。外加文件缓冲区的知识点。文件的顺序读写字符输入输出f