分类: C#2013-10-01 22:45 5335人阅读 评论(4) 收藏 举报
        前言:没买到1号回家的票,所以在祖国64岁生日之际,宅在宿舍一天,玩游戏之余把昨天想整理的log4net整理下,于是有了下文。
        log4net是一款优秀的第三方日志框架,可以很容易的加载到开发项目中(引用log4net的dll,再配置些基本参数即可),帮助程序员把日志信息输出到各种不同的目标,常见的有文本、数据库、windows日志、邮件、内存缓冲区等目标。

首先需要log4net的dll(源码中dll版本是1.2.10.0),引用到程序中,然后再配置下配置文件,配置文件如下:

  1. <?xml version="1.0"?>
  2. <configuration>
  3. <configSections>
  4. <section name="log4net"
  5. type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
  6. </configSections>
  7. <!--站点日志配置部分-->
  8. <log4net>
  9. <root>
  10. <!--控制级别,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF-->
  11. <!--比如定义级别为INFO,则INFO级别向下的级别,比如DEBUG日志将不会被记录-->
  12. <!--如果没有定义LEVEL的值,则缺省为DEBUG-->
  13. <level value="ERROR"/>
  14. <appender-ref ref="RollingFileAppender"/>
  15. </root>
  16. <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
  17. <!--日志文件名开头-->
  18. <file value="c:\Log\TestLog4net.TXT"/>
  19. <!--多线程时采用最小锁定-->
  20. <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
  21. <!--日期的格式,每天换一个文件记录,如不设置则永远只记录一天的日志,需设置-->
  22. <datePattern value="(yyyyMMdd)"/>
  23. <!--是否追加到文件,默认为true,通常无需设置-->
  24. <appendToFile value="true"/>
  25. <!--变换的形式为日期,这种情况下每天只有一个日志-->
  26. <!--此时MaxSizeRollBackups和maximumFileSize的节点设置没有意义-->
  27. <!--<rollingStyle value="Date"/>-->
  28. <!--变换的形式为日志大小-->
  29. <!--这种情况下MaxSizeRollBackups和maximumFileSize的节点设置才有意义-->
  30. <RollingStyle value="Size"/>
  31. <!--每天记录的日志文件个数,与maximumFileSize配合使用-->
  32. <MaxSizeRollBackups value="10"/>
  33. <!--每个日志文件的最大大小-->
  34. <!--可用的单位:KB|MB|GB-->
  35. <!--不要使用小数,否则会一直写入当前日志-->
  36. <maximumFileSize value="2MB"/>
  37. <!--日志格式-->
  38. <layout type="log4net.Layout.PatternLayout">
  39. <conversionPattern value="%date [%t]%-5p %c - %m%n"/>
  40. </layout>
  41. </appender>
  42. </log4net>
  43. </configuration>

然后代码如下:

  1. using System;
  2. using System.Reflection;
  3. using log4net;
  4. using log4net.Config;
  5. namespace Log4Net1001
  6. {
  7. class Program
  8. {
  9. static void Main(string[] args)
  10. {
  11. Console.WriteLine("Begin Run");
  12. XmlConfigurator.Configure();
  13. Type type = MethodBase.GetCurrentMethod().DeclaringType;
  14. ILog m_log = LogManager.GetLogger(type);
  15. m_log.Debug("这是一个Debug日志");
  16. m_log.Info("这是一个Info日志");
  17. m_log.Warn("这是一个Warn日志");
  18. m_log.Error("这是一个Error日志");
  19. m_log.Fatal("这是一个Fatal日志");
  20. Console.WriteLine("End");
  21. Console.ReadLine();
  22. }
  23. }
  24. }

运行结果,在c:\Log\TestLog4net.TXT文件中写了如下信息:
        2013-10-01 22:35:53,793 [10]ERROR Log4Net1001.Program - 这是一个Error日志
        2013-10-01 22:35:53,802 [10]FATAL Log4Net1001.Program - 这是一个Fatal日志

其中layout节点的配置说明:
        %m(message):输出的日志消息;
        %n(newline):换行;
        %d(datetime):输出当前语句运行的时刻;
        %r(runtime):输出程序从运行到执行到当前语句时消耗的毫秒数;
        %t(threadid):当前语句所在的线程ID ;
        %p(priority): 日志的当前日志级别;
        %c(class):当前日志对象的名称;
        %L:输出语句所在的行号;
        %F:输出语句所在的文件名; 
        %-10:表示最小长度为10,如果不够,则用空格填充;

其他开发时遇到的问题
        1.项目的目标框架为.NET Framework 3.5(或者4) Client Profile时会报出下图错误,改成.NET Framework 3.5(或者4) 即可;

2.当configSections节点没有放在configuration节点下的第一个节点时,编译时不会报警告,但运行时不会记日志。这是因为自定义的节点configSections这个必须放在第一个,这是app.config文件的语法规定;

3.对于大量记日志的程序,需注意配置RollingStyle值为Composite,且设置MaxSizeRollBackups(每天记录的日志文件个数)和maximumFileSize(每个日志文件的最大大小)。我以前遇过一次日志过大的问题,有一次版本临时发布就改了一个方法而没有经过测试,造成每天记几十G日志的,几天就把服务器磁盘弄满了。

4.当发现不记日志时,可从两方面调查问题,一是log4net有没有初始化,也就是XmlConfigurator.Configure();二是看level节点的配置是不是正确;

5.当发现一些设置参数没有起作用时,请检查是不是同一个节点被设置过多次,当被重复设置时,log4net会选择最后一个作为实际的设置。例如设置记录日志的级别设置两次如<level value="ERROR"/><level value="All"/>,则最终会以ALL作为记录日志的级别。

6.如果是网站项目,须在项目中的AssemblyInfo.cs文件的最后一行中添加:

  1. [assembly: log4net.Config.DOMConfigurator(ConfigFile = "Web.config", Watch = true)]

希望能对读者有些帮助,如果有什么错误或想法,还望不吝指教,转载请保留原文链接。项目实战见Log4net终极版。完整程序见源码,源码下载

log4net 极简配置的更多相关文章

  1. Spring Boot (七): Mybatis极简配置

    Spring Boot (七): Mybatis极简配置 1. 前言 ORM 框架的目的是简化编程中的数据库操作,经过这么多年的发展,基本上活到现在的就剩下两家了,一个是宣称可以不用写 SQL 的 H ...

  2. 虚拟机极简配置manjaro gnome

    一.安装gnome启动到桌面后,卸载所有不必要的软件,减少系统大小 打开[增加/删除软件],找到要删除的软件卸载 ms-office ---微软在线办公软件 Thunderbird ---邮箱 kon ...

  3. 极简配置phpstorm+xdebug进行断点调试

    以前调试的时候各种var_dump()就能得到结果,现在入手别人开发的工作,由于不了解业务和代码逻辑,又要去修改bug,就造成了修改bug效率低,所以又拾起来了xdbug,顺便总结了一下phpstor ...

  4. 走进JavaWeb技术世界16:极简配置的SpringBoot

    一位阿里 Java 工程师的技术小站.作者黄小斜,专注 Java 相关技术:SSM.SpringBoot.MySQL.分布式.中间件.集群.Linux.网络.多线程,偶尔讲点Docker.ELK,同时 ...

  5. 极简配置,业务上云只需 3min

    为了简化账号配置环节,实现本地一键开发部署,Serverless Framework 发布了微信扫码一键登录能力,支持用户在 Serverless Framework 环境扫码注册登陆,用户无需登录控 ...

  6. apache极简配置虚拟机

    在apache的httpd.conf文件最后添加: Listen 81<VirtualHost *:81> DocumentRoot E:/CM/wx_shop/ecshop</Vi ...

  7. 串口助手下载-带时间戳的串口助手-极简串口助手-V1.1 自动保存配置参数 能显示收发时间方便调试

    1.串口助手下载 2.带时间戳的串口助手,每次收发指令带上了时间戳,方便调试 3.极简串口助手 4.简单易用 高速稳定 5.每次修改的参数都能自动保存,免去了重复配置的工作 下载地址:http://w ...

  8. CentOS下使用Postfix + Dovecot + Dnsmasq搭建极简局域网邮件系统

    背景 开发环境为局域网,工作内容需要经常查看邮件文件(*.eml),可恶的Foxmail必须验证账户才能进入主界面,才能打开eml文件查看. 无奈搭一个局域网内的邮件系统吧.极简搭建,仅用于通过Fox ...

  9. 在Web应用中接入微信支付的流程之极简清晰版

    在Web应用中接入微信支付的流程之极简清晰版 背景: 在Web应用中接入微信支付,我以为只是调用几个API稍作调试即可. 没想到微信的API和官方文档里隐坑无数,致我抱着怀疑人生的心情悲愤踩遍了丫们布 ...

随机推荐

  1. 获取本机IP,返回字符串

    public static String GetLocalIp() { String[] Ips = GetLocalIpAddress(); foreach (String ip in Ips) i ...

  2. ubuntu16.04下安装TensorFlow(GPU加速)----详细图文教程【转】

    本文转载自:https://blog.csdn.net/zhaoyu106/article/details/52793183 le/details/52793183 写在前面 一些废话 接触深度学习已 ...

  3. Redis之Sorted Set 有序集合

    Redis Sorted Set 有序集合 Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员. 不同的是每个元素都会关联一个double类型的分数.redis正是通过分 ...

  4. class文件的结构

    任何一个class文件都对应着唯一一个类或接口的定义信息,但反过来说,类或接口的定义信息并不一定都在文件里(比如类或接口也可以通过类加载器直接生成) class文件是一组以8位字节为基础单位的二进制流 ...

  5. Python学习札记(四十一) IO 1

    参考:IO NOTE A.Pre 1.IO在计算机中指Input/Output,也就是输入和输出. 2.IO编程中,Stream(流)是一个很重要的概念,可以把流想象成一个水管,数据就是水管里的水,但 ...

  6. Educational Codeforces Round 17 C. Two strings 打表二分

    C. Two strings time limit per test 2 seconds memory limit per test 256 megabytes input standard inpu ...

  7. python 通过列表元素值截取列表并获取长度

    def count_range_in_list(li, min, max): ctr = for x in li: if min <= x <= max: ctr += return ct ...

  8. CAP原则和BASE理论

    CAP原则 CAP原则又称CAP定理,是一个经典的分布式系统理论.CAP理论告诉我们:一个分布式系统不可能同时满足一致性(C:Consistency).可用性(A:Availability)和分区容错 ...

  9. Cool Auto-Suggest 插件使用方法

    刚入职的时候公司主管曾经让我用Cool Auto-Suggest 插件写过后台管理页面内的自动填充及搜索功能. 其实这个插件的使用很简单,网上也有相应的翻译文档,但是明显的机翻看着无法忍受.我写一下使 ...

  10. cf812 C 二分

    C. Sagheer and Nubian Market time limit per test 2 seconds memory limit per test 256 megabytes input ...