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


猜你喜欢
- Spring整合Myabtis思路的分析引入相关依赖SpringMyabtismysqlMybatsi-spring…
- 我们在打包的过程中,需要对代码进行混淆处理,可项目中需要混淆的地方很多,特别是添加依赖的,如果要我们一个一个添加,无疑这大大的添加了我们的工
- 一、题目给你一个整数数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑
- 一、简介编写手机App时,有时需要使用文字转语音(Text to Speech)的功能,比如开车时阅读收到的短信、导航语音提示、界面中比较重
- 本文实例讲述了linux环境下java程序打包成简单的hello world输出jar包。分享给大家供大家参考,具体如下:1. linux必
- 如果运行react-native android项目出现如下错误:解决办法如下:一、执行adb devices,判断adb有没有断,二、如果
- 前言自从用了SpringBoot,个人最喜欢的就是SpringBoot的配置文件了,和Spring比起SpringBoot更加灵活,修改的某
- 本文实例为大家分享了Android文件下载功能的具体代码,供大家参考,具体内容如下1.普通单线程下载文件:直接使用URLConnection
- mybatis Integer类型参数动态sql注意条件例如以下拼接的动态sql<if test="work_status
- 下面提供三种计时器的写法供大家参考,大家可以自行选择自己钟爱的使用。写法一(Spring 包提供的计时器):import java.text
- Scala异常处理Scala是一种多范式的编程语言,支持面向对象和函数式编程。Scala也支持异常处理,即在程序运行过程中发生意外或错误时,
- 在idea中将创建的java web项目部署到Tomcat中采用的工具idea 2018.3.6 Tomcat71.先创建第一个新项目sec
- 效果明细用Popup实现的,录gif时,Popup显示不出来,不知道为什么,所以静态图凑合看吧大体思路图表使用Arc+Popup实现图表分为
- 1. 概述JDK * 是利用java反射机制 生成一个实现接口的匿名类, 在调用具体方法前调用InvocationHandler来处理Cg
- 一、项目中配置多语言多语言的实现是通过AndroidUtilCode实现的,表示感谢!项目里面有4种语言:中文,英文,德文,俄文。文件夹如下
- 本文实例为大家分享了java导出百万以上数据的excel文件,供大家参考,具体内容如下1.传统的导出方式会消耗大量的内存,2003每个she
- android 实现拨打电话的app,代码非常简单,功能也很实用,分享给大家。MainActivity.javapackage com.bb
- 1. 项目背景最近参加了Compose挑战赛的终极挑战,使用Compose完成了一个天气app。之前几轮挑战也都有参与,每次都学到不少新东西
- 一、什么是IOC1)控制反转,把创建对象和对象的调用过程交给Spring 管理。2)使用IOC的目的,为了降低耦合度。二、IOC的底层原理X
- 目录绘制流程Measure 测量流程MeasureSpeclayout 布局流程draw 绘制流程相关类 & 概念DecorView