一、 什么是 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. day4(编写注册接口)

    1.编写注册接口 1.1 user/urls.py中添加路由 urlpatterns = [    path('register/', views.RegisterView.as_view()),  ...

  2. PyQt(Python+Qt)学习随笔:QTabWidget选项卡部件当前项类属性currentIndex、currentTabText、currentTabName、currentTabIcon介绍

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 QTabWidget的当前项类属性为用于访问当前操作的选项卡,包括如下属性: 1. currentI ...

  3. 第14.5节 利用浏览器获取的http信息构造Python网页访问的http请求头

    一. 引言 在<第14.3节 使用google浏览器获取网站访问的http信息>和<第14.4节 使用IE浏览器获取网站访问的http信息>中介绍了使用Google浏览器和IE ...

  4. burp添加插件

    困扰了我很长时间的验证码,虽然迫使我早就找到了相关文章,但是由于一些原因,就推迟了验证码相关的东西.今天趁着晚上,好好的安装一下 下载地址 https://github.com/bit4woo/reC ...

  5. sql 执行语句函数

    # sql 语句执行函数 def get_access(request): uid=request cursor=connection.cursor() cursor.execute("se ...

  6. ORA-28017: The password file is in the legacy format

    1.数据库升级后修改sys密码报错. 一般从oracle 从11G(11.2.0.4)升级到12C或者19C,修改SYS密码会有以下报错: ORA-28017: The password file i ...

  7. glances linux资源使用监控

    安装 yum install glances -y 界面 介绍 命令选项 -b:显示网络连接速度 Byte/ 秒 -B @IP|host :绑定服务器端 IP 地址或者主机名称 -c @IP|host ...

  8. Django使用channels实现Websocket连接

    简述: 需求:消息实时推送消息以及通知功能,采用django-channels来实现websocket进行实时通讯.并使用docker.daphne启动通道,保持websocket后台运行 介绍Dja ...

  9. layui的基本使用

    打开官网https://www.layui.com/下载这个框架 官网首页 下载到 layui 的最新版,它经过了自动化构建,更适合用于生产环境.目录结构如下 ├─css //css目录 │ │─mo ...

  10. matplotlib的学习15-次坐标轴

    import matplotlib.pyplot as plt import numpy as np x = np.arange(0, 10, 0.1) y1 = 0.05 * x**2 y2 = - ...