一、 什么是 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 }

运行程序后,实际输出效果如下:

 四、引用地址

  1. http://logging.apache.org/log4net/release/manual/configuration.html
  2. https://www.sohu.com/a/254335960_696685
  3. https://blog.csdn.net/hr541659660/article/details/45575473

C# 使用 log4net 日志组件的更多相关文章

  1. .net core 使用log4net日志组件

    一个web站点必须要记录日志,否则哪里出错了,完全是黑娃找黑妹,两眼一抹黑. 最常用的就是log4net日志组件.我们可以通过扩展加入日志组件. 第一步:在项目中NuGet log4net包,即 In ...

  2. log4net日志组件经验分享

    引自log4net日志组件经验分享 我们在开发WEB项目的时候,经常会出现这样的情况:在本地调试都是正常的,但是部署到服务器上就不行了.一般出现这种情况很大一部分原因是因为服务的环境和本地不同,数据库 ...

  3. 快速入门系列--Log4net日志组件

    Log4net是阿帕奇基金会的非常流行的开源日志组件,是log4j的.NET移植版本,至今已经有11年的历史,使用方便并且非常稳定,此外很重要的一点是其和很多开源组件能很好的组合在一起工作,例如NHi ...

  4. C#控制台程序使用Log4net日志组件

    1.Log4net一般都不陌生,但是在配置上不同类型的项目又不相同的地方比如C#控制台程序和C# MVCWeb项目,拿控制台项目为例   项目源码在文章底部 2.首先创建一个控制台程序,引入Log4n ...

  5. log4net日志组件

    转载:http://www.cnblogs.com/knowledgesea/archive/2012/04/26/2471414.html 一.什么是log4net组件 Log4net是基于.net ...

  6. Log4net日志组件使用

    一.简介 几乎所有的大型应用都会有自己的用于跟踪调试的API.因为一旦程序被部署以后,就不太可能再利用专门的调试工具了.然而一个管理员可能需要有一套强大的日志系统来诊断和修复配置上的问题.经验表明,日 ...

  7. 使用log4net日志组件经验分享

    常见步骤: 第一:在项目中引用log4net组件. 第二:配置log4net,一般都写在web.config中. 第三:调用部分.       具体怎么配置,大家可以参考博客其它博友写的,这里我只写我 ...

  8. 性能秒杀log4net的NLogger日志组件(附测试代码与NLogger源码)

    NLogger特性: 一:不依赖于第三方插件和支持.net2.0 二:支持多线程高并发 三:读写双缓冲对列 四:自定义日志缓冲大小 五:支持即时触发刷盘机制 六:先按日期再按文件大小滚动Rolling ...

  9. .Netcore之日志组件Log4net、Nlog性能比较

    转载请注明出处http://www.cnblogs.com/supernebula/p/7506993.html .Netcore之Log4net.Nlog性能比较 最近在写一个开源.netcore ...

随机推荐

  1. 跳表(SkipList)原理篇

    1.什么是跳表? 维基百科:跳表是一种数据结构.它使得包含n个元素的有序序列的查找和插入操作的平均时间复杂度都是 O(logn),优于数组的 O(n)复杂度.快速的查询效果是通过维护一个多层次的链表实 ...

  2. moviepy音视频开发:音频合成类CompositeAudioClip介绍

    ☞ ░ 前往老猿Python博文目录 ░ CompositeAudioClip是AudioClip的直接子类,用于将几个音频剪辑合成为一个音频剪辑.CompositeAudioClip类只有一个构造方 ...

  3. moviepy音视频开发专栏文章目录

    ☞ ░ 前往老猿Python博文目录 ░ <moviepy音视频开发专栏>为收费专栏,基于老猿阅读moviepy1.03版本的源代码以及大量测试验证的基础上,详细介绍moviepy主要音视 ...

  4. DVWA SQL Injection LOW

    最近在学习SQL注入,初出茅庐,就从dvwa开始吧 sql注入可以通过sqlmap工具实现,为了更好地了解原理,这里主要是手工注入 注入的一般流程为: 1,找到注入点,此步骤可通过工具 2,判断注入类 ...

  5. js防抖与节流了解一下

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. js数组快速排序和冒泡排序

    1.快速排序 var arr = [1, 2, 5, 6, 3, 1, 4]; function mySort(arr) { if (arr.length <= 1) { return arr; ...

  7. Angular:惰性加载的模块

    ①通过ng new angular-module创建一个全新的angular应用,默认不选路由 ②通过一下命令分别创建2个模块和1个组件 ng g m hx1 ng g c hx1 ng g m hx ...

  8. css样式规则

    在css样式规则中: 1.选择器用于指定CSS样式作用的HTML对象,花括号内是对该对象设置的具体样式. 2.属性和属性值以"键值对"的形式出现. 3.属性是对指定的对象设置的样式 ...

  9. elasticsearch-head 配置

    elasticsearch-head install node.js Download node.js: 将下载的包,解压并配置环境变量  vim /etc/profile  ​ #set for n ...

  10. 工具-python包-虚拟环境管理(99.4.1)

    @ 目录 1.第一种方法-virtualenv 2.第二种方法-pycharm 关于作者 1.第一种方法-virtualenv 1.安装 pip install virtualenv pip inst ...