C# 使用 log4net 日志组件
一、 什么是 log4net
Apache log4net 库是帮助程序员将日志语句输出到各种输出目标的工具,它是从Java中的Log4j迁移过来的一个.Net版的开源日志框架。log4net 的一个显著特征是分层记录器的概念。使用这些记录器可以有选择地控制以任意粒度输出哪些日志语句。主要特征如下:
- 支持多个框架
- 输出到多个日志记录目标
- 分层日志记录体系结构
- XML 配置
- 动态配置
- 日志记录上下文
- 久经考验的架构
- 模块化和可扩展设计
- 高性能和灵活性
二、C# 使用 log4net
添加Nuget 包,搜索到“log4net”后 ,选择安装,具体如下图所示:
三、添加 log4net 配置文件
使用 log4net需要我们配置log4net的配置文件,目前,配置文件是用 XML 编写的。一般有两种方式,一种是使用og4net自动生成的 “log4net.xml”进行配置,另一种是直接嵌入到运行程序的 app.config 文件中。
具体内容如下:


1 <?xml version="1.0" encoding="utf-8" ?>
2 <configuration>
3 <configSections>
4 <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
5 </configSections>
6 <startup>
7 <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
8 </startup>
9 <log4net>
10 <!-- OFF, FATAL, ERROR, WARN, INFO, DEBUG, ALL -->
11 <!-- Set root logger level to ERROR and its appenders -->
12 <root>
13 <level value="ALL" />
14 <appender-ref ref="SysAppender" />
15 </root>
16 <!-- Print only messages of level DEBUG or above in the packages -->
17 <logger name="WebLogger">
18 <level value="DEBUG" />
19 </logger>
20 <appender name="SysAppender" type="log4net.Appender.RollingFileAppender,log4net">
21 <param name="File" value="log/" />
22 <param name="AppendToFile" value="true" />
23 <param name="RollingStyle" value="Date" />
24 <param name="DatePattern" value="'demo_'yyyy_MM_dd-HH'.log'" />
25 <param name="StaticLogFileName" value="false" />
26 <param name="RollingStyle" value="Composite" />
27 <layout type="log4net.Layout.PatternLayout,log4net">
28 <param name="ConversionPattern" value="%date [th=%3thread] [line:%5L] [%-5level] %message%newline"/>
29 </layout>
30 </appender>
31 <appender name="consoleApp" type="log4net.Appender.ConsoleAppender,log4net">
32 <layout type="log4net.Layout.PatternLayout,log4net">
33 <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n" />
34 </layout>
35 </appender>
36 </log4net>
37 </configuration>
主要参数含义如下:
三、源码测试
我们可以添加一个日志类,专门用于输出日志打印,具体代码如下:


1 public static class LogUtil
2 {
3 private static log4net.ILog Log { get; } = log4net.LogManager.GetLogger("log");
4
5
6 public static void Configure(string exeConfigFile)
7 {
8 log4net.Config.XmlConfigurator.Configure(new System.IO.FileInfo(exeConfigFile));
9 }
10
11 private static string GetMethodName(int skipFrames = 2)
12 {
13 try
14 {
15 // 这里忽略skipFrames层堆栈,也就忽略了当前方法GetMethodName,以及调用此方法的方法,这样拿到的就正好是外部调用打印日志所在函数的方法信息
16 var method = new StackFrame(skipFrames).GetMethod();
17 var properties =
18 method?.DeclaringType?.GetProperties(
19 BindingFlags.Instance |
20 BindingFlags.Static |
21 BindingFlags.Public |
22 BindingFlags.NonPublic);
23 var property = properties?.Where(p => p.GetGetMethod(true) == method || p.GetSetMethod(true) == method)
24 .FirstOrDefault();
25
26 var name = $"{method?.DeclaringType?.ToString().Split('.').Last()}.{method?.Name}";
27 return property == null
28 ? $"{name,-50}"
29 : $"{property.Name,-50}";
30 }
31 catch (Exception e)
32 {
33 return "ERROR TO GET CALLING METHOD";
34 }
35 }
36 private static string NoWarp(string msg)
37 {
38 return msg?.Replace("\r\n", " ").Replace("\n", " ");
39 }
40 private static string WrapException(string msg, Exception e)
41 {
42 var builder = new StringBuilder(msg);
43 builder.Append("\t[").Append(e.Message).Append("]");
44 if (e.InnerException != null)
45 {
46 builder.Append(" --> [").Append(e.InnerException.Message).Append("]");
47 }
48
49 return builder.ToString();
50 }
51
52
53
54
55 public static void Debug(string msg)
56 {
57 Log.Debug(msg);
58 }
59 public static void Debug(string msg, Exception e)
60 {
61 Log.Debug(WrapException(msg, e), e);
62 }
63
64 public static void Info(string msg)
65 {
66 Log.Info(msg);
67 }
68 public static void Info(string msg, Exception e)
69 {
70 Log.Info(WrapException(msg, e), e);
71 }
72
73 public static void Warn(string msg)
74 {
75 Log.Warn(msg);
76 }
77 public static void Warn(string msg, Exception e)
78 {
79 Log.Warn(WrapException(msg, e), e);
80 }
81
82 public static void Error(string msg)
83 {
84 Log.Error(msg);
85 }
86 public static void Error(string msg, Exception e)
87 {
88 Log.Error(WrapException(msg, e), e);
89 }
90
91 public static void Fatal(string msg)
92 {
93 Log.Fatal(msg);
94 }
95 public static void Fatal(string msg, Exception e)
96 {
97 Log.Fatal(WrapException(msg, e), e);
98 }
99 }
测试代码如下:


1 static void Main(string[] args)
2 {
3 try
4 {
5 string exeConfigFile = $"{AppDomain.CurrentDomain.BaseDirectory}//Log4netDemo.exe.config";
6
7 if (File.Exists(exeConfigFile) == false)
8 {
9 throw new Exception($"应用程序配置文件 [{exeConfigFile}] 不存在,无法加载日志 log4net 的配置");
10 }
11
12 XmlConfigurator.Configure(new FileInfo(exeConfigFile));
13 LogUtil.Info("====================================== Log4netDemo started, log4net setup...");
14 LogUtil.Warn("程序启动入参不合理");
15 LogUtil.Error("程序启动失败");
16
17 Console.ReadKey();
18 }
19 catch (Exception ex)
20 {
21 Console.WriteLine(ex);
22 LogUtil.Error("程序加载失败",ex);
23 }
24 }
运行程序后,实际输出效果如下:
四、引用地址
- http://logging.apache.org/log4net/release/manual/configuration.html
- https://www.sohu.com/a/254335960_696685
- https://blog.csdn.net/hr541659660/article/details/45575473
C# 使用 log4net 日志组件的更多相关文章
- .net core 使用log4net日志组件
一个web站点必须要记录日志,否则哪里出错了,完全是黑娃找黑妹,两眼一抹黑. 最常用的就是log4net日志组件.我们可以通过扩展加入日志组件. 第一步:在项目中NuGet log4net包,即 In ...
- log4net日志组件经验分享
引自log4net日志组件经验分享 我们在开发WEB项目的时候,经常会出现这样的情况:在本地调试都是正常的,但是部署到服务器上就不行了.一般出现这种情况很大一部分原因是因为服务的环境和本地不同,数据库 ...
- 快速入门系列--Log4net日志组件
Log4net是阿帕奇基金会的非常流行的开源日志组件,是log4j的.NET移植版本,至今已经有11年的历史,使用方便并且非常稳定,此外很重要的一点是其和很多开源组件能很好的组合在一起工作,例如NHi ...
- C#控制台程序使用Log4net日志组件
1.Log4net一般都不陌生,但是在配置上不同类型的项目又不相同的地方比如C#控制台程序和C# MVCWeb项目,拿控制台项目为例 项目源码在文章底部 2.首先创建一个控制台程序,引入Log4n ...
- log4net日志组件
转载:http://www.cnblogs.com/knowledgesea/archive/2012/04/26/2471414.html 一.什么是log4net组件 Log4net是基于.net ...
- Log4net日志组件使用
一.简介 几乎所有的大型应用都会有自己的用于跟踪调试的API.因为一旦程序被部署以后,就不太可能再利用专门的调试工具了.然而一个管理员可能需要有一套强大的日志系统来诊断和修复配置上的问题.经验表明,日 ...
- 使用log4net日志组件经验分享
常见步骤: 第一:在项目中引用log4net组件. 第二:配置log4net,一般都写在web.config中. 第三:调用部分. 具体怎么配置,大家可以参考博客其它博友写的,这里我只写我 ...
- 性能秒杀log4net的NLogger日志组件(附测试代码与NLogger源码)
NLogger特性: 一:不依赖于第三方插件和支持.net2.0 二:支持多线程高并发 三:读写双缓冲对列 四:自定义日志缓冲大小 五:支持即时触发刷盘机制 六:先按日期再按文件大小滚动Rolling ...
- .Netcore之日志组件Log4net、Nlog性能比较
转载请注明出处http://www.cnblogs.com/supernebula/p/7506993.html .Netcore之Log4net.Nlog性能比较 最近在写一个开源.netcore ...
随机推荐
- PyQt(Python+Qt)学习随笔:QTableWidgetItem的构造方法
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 QTableWidgetItem类为QTableWidget类的项实例类,用于保存表格部件的信息.项 ...
- 推荐系统(CTR领域)实战入门指南
CTR经典模型如:FM,FFM,Wide&Deep,建议自己去复现一个完整的通用模型 先从pytorch版本入手(后期考虑tensorflow),从kaggle上找实际的比赛 github 相 ...
- ActionResult的返回类型
ActionResult是控制器方法执行后返回的结果类型,控制器方法可以返回一个直接或间接从ActionResult抽象类继承的类型,如果返回的是非ActionResult类型,控制器将会将结果转换为 ...
- 【学习笔记】最小直径生成树(MDST)
简介 无向图中某一点(可以在顶点上或边上),这个点到所有点的最短距离的最大值最小,那么这个点就是 图的绝对中心. 无向图所有生成树中,直径最小的一个,被称为 最小直径生成树. 图的绝对中心的求法 下文 ...
- 搞定MySQL安装难安装贵问题
背景 本方案解决了windows下安装MySQL过程繁琐的问题. 是真正的免安装绿色方法,不用配环境变量,不用执行install命令,不用配置my.ini文件. 步骤 下载 下载mysql-8.0.2 ...
- DVWA各级文件包含漏洞
File Inclusion文件包含漏洞 漏洞分析 程序开发人员通常会把可重复使用的函数写入到单个文件中,在使用某些函数时,直接调用此文件,而无需再次编写,这种调用文件的过程被称为包含. 有时候由于网 ...
- mysql 8.0忘记root密码
1.修改参数文件添加以下内容 skip-grant-tables 2.关闭数据库 [root@node01 ~]# /etc/init.d/mysqld8 stop Shutting down MyS ...
- 基于Python PIL实现简单图片格式转化器
基于Python PIL实现简单图片格式转化器 目录 基于Python PIL实现简单图片格式转化器 1.简介 2.前期资料准备 2.1.1如何实现图片格式转换? 2.1.2如何保存需要大小的图片? ...
- 在IDEA中使用JDBC获取数据库连接时的报错及解决办法
在IDEA中使用JDBC获取数据库连接时,有时会报错Sat Dec 19 19:32:18 CST 2020 WARN: Establishing SSL connection without ser ...
- 解决Yii ActiveForm监听submit触发2次submit
今天用yii框架的ActiveForm需要一个奇怪的问题,点击表单提交时会触发两次submit 产生问题的原因: form挂了2次submit事件,一次是yii activeform自带的,一次是我写 ...