背景

最近在写一个Adapter,需要调用别的程序的DLL. Adapter使用的是C#还有.net的等方面的技术。今天在写log这块,就像尝试一下有没有“轮子”可以试试的。在网上搜罗了一番之后,决定就使用“log4net”吧。

关于log4net

简单来说,她是从log4j衍生出来的专门用于.net领域的一个写log的类库。支持 .net stardard,.net core等等。。。

下载

我们可以到 http://logging.apache.org/log4net/download_log4net.cgi 来下载,下载页面提供了很多种方式(binary or source)

使用

LZ这里是.net stardard,所以将下载完成后的压缩包解压,之后进入bin目录,找到对应的framework版本,选择引入“log4net.dll”

个人的想法是把这个记录log的组件封装成一个library,所以新建一个ClassLibrary工程,在里面引入“log4net.dll”并且进行封装。项目组成如下图:

其中:

- LogHelper  是一个关于调用Log4net.dll方法的封装类。

- LogLirary.config 该文件是一个配置文件,里面详细记录的log的输出/存储方式

LogHelper.cs

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5.  
  6. [assembly: log4net.Config.XmlConfigurator(ConfigFile = "LogLibrary.config", ConfigFileExtension = ".config", Watch = true)]
  7. namespace LogLibary
  8. {
  9.  
  10. public enum LogLevel
  11. {
  12. Debug,
  13. Info,
  14. Warning,
  15. Error
  16. }
  17.  
  18. public class LogHelper
  19. {
  20. public static void WriteLog(Type t, LogLevel logLevel, string msg)
  21. {
  22. log4net.ILog log = log4net.LogManager.GetLogger(t);
  23. switch (logLevel)
  24. {
  25. case LogLevel.Debug:
  26. log.Debug(msg);
  27. break;
  28.  
  29. case LogLevel.Info:
  30. log.Info(msg);
  31. break;
  32.  
  33. case LogLevel.Warning:
  34. log.Warn(msg);
  35. break;
  36.  
  37. case LogLevel.Error:
  38. log.Error(msg);
  39. break;
  40.  
  41. default:
  42. log.Debug(msg);
  43. break;
  44. }
  45. }
  46.  
  47. public static void WriteLogWithException(Type t, LogLevel logLevel, string msg, Exception ex)
  48. {
  49. log4net.ILog log = log4net.LogManager.GetLogger(t);
  50. switch (logLevel)
  51. {
  52. case LogLevel.Debug:
  53. log.Debug(msg, ex);
  54. break;
  55.  
  56. case LogLevel.Info:
  57. log.Info(msg, ex);
  58. break;
  59.  
  60. case LogLevel.Warning:
  61. log.Warn(msg, ex);
  62. break;
  63.  
  64. case LogLevel.Error:
  65. log.Error(msg, ex);
  66. break;
  67.  
  68. default:
  69. log.Debug(msg, ex);
  70. break;
  71. }
  72. }
  73.  
  74. }
  75. }
  1. 标红的语句非常重要,它表明我们log输出依赖于configuration

LogLibrary.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. <log4net>
  7. <!--定义输出到文件中-->
  8. <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
  9. <!--定义文件存放位置-->
  10. <file value="Log\\"/>
  11. <appendToFile value="true"/>
  12. <rollingStyle value="Date"/>
  13. <datePattern value="yyyy\\yyyyMM\\yyyyMMdd'.txt'"/>
  14. <staticLogFileName value="false"/>
  15. <param name="MaxSizeRollBackups" value=""/>
  16. <layout type="log4net.Layout.PatternLayout">
  17. <!--每条日志末尾的文字说明-->
  18. <!--输出格式-->
  19. <!--样例:-- ::, [] INFO Log4NetDemo.MainClass [(null)] - info-->
  20. <conversionPattern value="%newline %n记录时间:%date %n线程ID:[%thread] %n日志级别: %-5level %n出错类:%logger property: [%property{NDC}] - %n错误描述:%message%newline %n"/>
  21. </layout>
  22. </appender>
  23. <!--定义输出到控制台命令行中-->
  24. <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
  25. <layout type="log4net.Layout.PatternLayout">
  26. <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
  27. </layout>
  28. </appender>
  29. <root>
  30. <level value="ALL" />
  31. <!--文件形式记录日志-->
  32. <appender-ref ref="RollingLogFileAppender" />
  33. <!--控制台控制显示日志-->
  34. <appender-ref ref="ConsoleAppender" />
  35. </root>
  36. </log4net>
  37. </configuration>

最后,写一个简单的测试类

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using RabbitMQ.Client;
  6. using LogLibary;
  7.  
  8. namespace Producer
  9. {
  10. class Program
  11. {
  12. static void Main(string[] args)
  13. {
  14. for (int i = ; i < ; i++) // tested code here
  15. {
  16.   string message = String.Format("Hello there! number is: {0}", i.ToString());
  17. LogHelper.WriteLog(typeof(Program), LogLevel.Debug, string.Format(" set {0}", message));
  18. }
  19.  
  20. LogHelper.WriteLog(typeof(Program), LogLevel.Info, "1000 tasks sent out!!");
  21.  
  22. Console.ReadKey();
  23. }
  24. }
  25. }

参考文献:

http://logging.apache.org/log4net/release/config-examples.html

http://www.cnblogs.com/wangsaiming/archive/2013/01/11/2856253.html

OK. 啰啰嗦嗦写了一堆,感谢大家的收看,预祝各位双11 “买买买!!”

log4donet 的 一篇简单使用实例的更多相关文章

  1. ASP.NET MVC 4 插件化架构简单实现-实例篇

    先回顾一下上篇决定的做法: 1.定义程序集搜索目录(临时目录). 2.将要使用的各种程序集(插件)复制到该目录. 3.加载临时目录中的程序集. 4.定义模板引擎的搜索路径. 5.在模板引擎的查找页面方 ...

  2. MVC 4 插件化架构简单实现实例篇

    ASP.NET MVC 4 插件化架构简单实现-实例篇   先回顾一下上篇决定的做法: 1.定义程序集搜索目录(临时目录). 2.将要使用的各种程序集(插件)复制到该目录. 3.加载临时目录中的程序集 ...

  3. Redis:安装、配置、操作和简单代码实例(C语言Client端)

    Redis:安装.配置.操作和简单代码实例(C语言Client端) - hj19870806的专栏 - 博客频道 - CSDN.NET Redis:安装.配置.操作和简单代码实例(C语言Client端 ...

  4. 运用Unity实现依赖注入[结合简单三层实例]

    运用Unity实现依赖注入[结合简单三层实例] 一:理论部分 依赖注入:这是 Ioc 模式的一种特殊情况,是一种基于改变对象的行为而不改变类的内部的接口编程技术.开发人员编写实现接口的类代码,并基于接 ...

  5. iOS开发网络篇—简单介绍ASI框架的使用

    iOS开发网络篇—简单介绍ASI框架的使用 说明:本文主要介绍网络编程中常用框架ASI的简单使用. 一.ASI简单介绍 ASI:全称是ASIHTTPRequest,外号“HTTP终结者”,功能十分强大 ...

  6. iOS开发UI篇—简单的浏览器查看程序

    iOS开发UI篇—简单的浏览器查看程序 一.程序实现要求 1.要求 2. 界面分析 (1) 需要读取或修改属性的控件需要设置属性 序号标签 图片 图片描述 左边按钮 右边按钮 (2) 需要监听响应事件 ...

  7. iOS开发UI篇—简单介绍静态单元格的使用

    iOS开发UI篇—简单介绍静态单元格的使用 一.实现效果与说明 说明:观察上面的展示效果,可以发现整个界面是由一个tableview来展示的,上面的数据都是固定的,且几乎不会改变. 要完成上面的效果, ...

  8. iOS开发Swift篇—简单介绍

    iOS开发Swift篇—简单介绍 一.简介 Swift是苹果于2014年WWDC(苹果开发者大会)发布的全新编程语言 Swift在天朝译为“雨燕”,是它的LOGO 是一只燕子,跟Objective-C ...

  9. Linux简单程序实例(GNU工具链,进程,线程,无名管道pipe,基于fd的文件操作,信号,scoket)

    一, GNU工具链简介: (1)编译代码步骤: 预处理 -> 编译 -> 汇编 -> 链接: 预处理:去掉注释,进行宏替换,头文件包含等工作: gcc -E test.c -o te ...

随机推荐

  1. 12 Nonlinear Transformation

    一.二次假设 实际上线性假设的复杂度是受到限制的, 需要高次假设打破这个限制 假设数据不是线性可分的,但是可以被一个圆心在原点的圆分开, 需要我们重新设计基于该圆的PLA等算法吗 不用, 只需要通过非 ...

  2. iOS连续dismiss几个ViewController的方法

    原文链接:http://blog.csdn.net/longshihua/article/details/51282388 presentViewController是经常会用到的展现ViewCont ...

  3. load data(sql)

    一般对于数据库表的插入操作,我们都会写程序执行插入sql,插入的数据少还可以,如果数据多了.执行效率上可能就不太理想了.load data语句用于高速地从一个文本文件中读取数据,装载到一个表中,相比于 ...

  4. 关于 String 自我理解

    String 的一些认识: String对象是不可变,所以使用 final 修饰 字符串拼接,合理利用 StringBuilder(线程非安全),StringBuffer 线程安全 常用方法就不详细介 ...

  5. 【codevs1001】[bzoj1050]舒适的路线

    给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求 一条路径,使得路径上最大边和最小边的比值最小. ...

  6. jvm内存模型的理解

    今天周六,又开始啃一遍<深入理解java虚拟机>每次读的感觉不一样,大学代码量较少,读起来也就死记硬背. 1.堆:长度可变,运行时使用的变量:存放对象(new )和数组之类: 2.栈:长度 ...

  7. 从字符串获得MAC地址的方法

    今日有感于编程水平下降,特意练习一下,根据MAC地址字符串,获取MAC地址的2种方法. #include <stdio.h> void func1(char *str){ unsigned ...

  8. java类加载小记

    java类只有当创建实体或被调用时才会加载,加载时按 编码顺序 先加载static后加载普通的.static模块和static变量都是同一等级的,谁写前面就先加载谁. 在调用某个静态类的方法时,会按编 ...

  9. Win10 UWP xaml 延迟加载元素

    xaml新增x:DeferLoadStrategy里面只有Lazy,查询了百度看到MSP_甄心cherish大神说的 xaml使用x:DeferLoadStrategy="Lazy" ...

  10. layim+signalr2.0在线轻聊版解决方案

    本内容有版权限制,仅提供学习交流参考等等,请勿随便转载或者代码商用.     /** layui-v2.1.5 MIT License By http://www.layui.com */; layu ...