1、Log4Net是什么?

      Log4Net是用来记录日志的,可以将程序运行过程中的信息输出到一些地方(文件、数据库、EventLog等)
 
2、Appender
     Appender:可以将日志输出到不同的地方,不同的输出目标对应不同的Appender:RollingFileAppender(滚动文件)、AdoNetAppender(数据库)、SmtpAppender (邮件)等
 
3、 level
     level(级别):标识这条日志信息的重要级别。None>Fatal>ERROR>WARN>DEBUG>INFO>ALL,设定一个Level,那么低于这个Level的日志是不会被写到Appender中的
 
4、配置一个Log4NetDemo的环境步骤
     (1)、新建一个控制台项目,添加一个“应用程序配置文件”(App.config)
     (2)、在App.Config或者Web.Config的添加如下配置:
             <!--Log4net块配置-->
     < configSections>
      < section name ="log4net " type ="log4net.Config.Log4NetConfigurationSectionHandler, log4net "/>
     </configSections>
 
     <log4net>
      <!-- 定义一些 appenders -->
      < appender name ="RollingLogFileAppender " type ="log4net.Appender.RollingFileAppender ">
      <!-- 写到哪个文件里去 -->
      < file value ="test.txt "/>
      <!-- 往文件里追加 -->
      < appendToFile value ="true "/>
      <!-- 最多10个日志备份文件 -->
      < maxSizeRollBackups value ="10 "/>
      <!-- 每个文件最大为1M -->
      < maximumFileSize value ="1024KB "/>
      <!-- 回滚的格式按照大小 -->
      < rollingStyle value ="Size "/>
      < staticLogFileName value ="true "/>
      <!--日志输出格式-->
      < layout type ="log4net.Layout.PatternLayout ">
       < conversionPattern value ="%date [%thread] %-5level %logger - %message%newline "/>
       </ layout>
       </ appender>
       < root>
     <!--定义level级别值和appender的列表-->
      < level value ="DEBUG "/>
      < appender-ref ref ="RollingLogFileAppender "/>
      </ root>
  </log4net>
     (3)、添加对log4net.dll的引用
     (4)、初始化:在程序最开始加入log4net.Config.XmlConfigurator.Configure();
     (5)、在要打印日志的地方LogManager.GetLogger(typeof(Program)).Debug("信息"); 通过LogManager.GetLogger传递要记录的日志类类名获得这个类的ILog(这样在      日志文件中就能看到这条日志是哪个类输出的了),然后调用Debug方法输出消息。因为一个类内部不止一个地方要打印日志,所以一般把ILog声明为一个static字段。
     (6)、输出错误信息用ILog.Error方法,第二个参数可以传递Exception对象。log.Error("***错误"+ex),log.Error("***错误",ex)
 
  主程序代码:
  amespace log4netDemo

{
          class Program
         {
             private static ILog log = LogManager.GetLogger(typeof(Program));
             static void Main(string[] args)
             {

              //从配置文件读取log4net的配置,然后进行初始化操作
                 log4net.Config.XmlConfigurator.Configure();
                 log.Debug("调试");
                 log.Error("出错");
             }
         }
      }

 运行结果:在该程序bin/Debug目录下生成test.txt文本文件,内容如下:  

2013-10-20 00:39:24,730 [8] DEBUG log4netDemo.Program - 调试
  2013-10-20 00:39:24,743 [8] ERROR log4netDemo.Program - 出错

初学Log4Net的更多相关文章

  1. DDD初学指南

    去年就打算总结一下,结果新换的工作特别忙,就迟迟没有认真动手.主要内容是很多初学DDD甚至于学习很长时间的同学没有弄明白DDD是什么,适合什么情况.这世界上没有银弹,抛开了适合的场景孤立的去研究DDD ...

  2. gulp初学

    原文地址:gulp初学 至于gulp与grunt的区别,用过的人都略知一二,总的来说就是2点: 1.gulp的gulpfile.js  配置简单而且更容易阅读和维护.之所以如此,是因为它们的工作方式不 ...

  3. 初学seaJs模块化开发,利用grunt打包,减少http请求

    原文地址:初学seaJs模块化开发,利用grunt打包,减少http请求 未压缩合并的演示地址:demo2 学习seaJs的模块化开发,适合对seajs基础有所了解的同学看,目录结构 js — —di ...

  4. Log4net - 规则简介

    参考页面: http://www.yuanjiaocheng.net/CSharp/csharprumenshili.html http://www.yuanjiaocheng.net/entity/ ...

  5. Log4net - 项目使用的一个简单Demo

    参考页面: http://www.yuanjiaocheng.net/entity/entitytypes.html http://www.yuanjiaocheng.net/entity/entit ...

  6. log4net使用手册

    1. log4net简介 log4net是.Net下一个非常优秀的开源日志记录组件.log4net记录日志的功能非常强大.它可以将日志分不同的等级,以不同的格式,输出到不同的媒介.Java平台下,它还 ...

  7. Log4Net应用问题

    问题 一.日志存储方式 1.txt 2.SQLServer数据库 3.log文件 二.项目类型不同 1winFrom 2webFrom 3MVC 4WPF 5控制台 三.切分依据不同 1.空间大小 2 ...

  8. 在C#代码中应用Log4Net系列教程(附源代码)

    Log4Net应该可以说是DotNet中最流行的开源日志组件了.以前需要苦逼写的日志类,在Log4Net中简单地配置一下就搞定了.没用过Log4Net,真心不知道原来日志组件也可以做得这么灵活,当然这 ...

  9. Log4net入门(帮助类篇)

    在前几篇Log4net入门文件的讲述过程中,我们在使用log4net的类中都要编写如下一行代码: private static log4net.ILog log = log4net.LogManage ...

随机推荐

  1. 1083: [SCOI2005]繁忙的都市

    1083: [SCOI2005]繁忙的都市 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1319  Solved: 878[Submit][Stat ...

  2. Java设计模式之《调停者模式》及应用场景

    原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/6518603.html 调停者模式. 我们想象一下这样的场景:一个系统内部通过许多的类互相之 ...

  3. 你的外接键盘的小键盘在Num Lock键亮着的,但是数字按了不能用,解决办法在这里

    1.可能是Num Lock键卡住了导致的,你多按几次numlock键试试. 如果上面的不行,你就再试试下面的这个: 2.系统下开启了启用鼠标键导致的,解决的方法如下: (1).打开"控制面板 ...

  4. [译]Selenium Python文档:三、导航控制

    你使用WebDriver要做的第一件事就是访问一个链接.一般通过调用get方法来实现: driver.get("http://www.baidu.com") 在将控制权返给你的脚本 ...

  5. java学习笔记 --- 数组

    一.Java的内存分配   A:栈内存: 存储局部变量,只要是在方法中定义的变量都是局部变量.一旦变量的生命周期结束该变量就被释放.   B:堆内存: 存储所有new出来的,及实体(对象),每一个实体 ...

  6. 对Golang有兴趣的朋友,推荐一款go语言Web框架-dotweb

    Go语言,2009年推出,对我个人,2015年下半年,才下定决心正式开始引入使用Go,自此,让我获得了一种全新的开发体验. 在不断的项目过程中,一个开发人员总喜欢堆积一些代码段,由于Go的开源特性,逐 ...

  7. java实现八种排序算法并测试速度(详细)

    算法代码: /** * Created by CLY on 2017/3/17. */ package pers.cly.sorting; /** * 排序工具类,里面包含各种排序方法 */ publ ...

  8. 创建keystone的catalog时提示:‘Internal Server Error (HTTP 500)’

    在生成keystone的catalog时: [root@controller ~]# openstack service create --name keystone --description &q ...

  9. 转载linux c语言程序的Makefile编写

    对于程序设计员来说,makefile是我们绕不过去的一个坎.可能对于习惯Visual C++的用户来说,是否会编写makefile无所谓.毕竟工具本身已经帮我们做好了全部的编译流程.但是在Linux上 ...

  10. 【转】flash air中读取本地文件的三种方法

    actionscript中读取本地文件操作有两种代码如下 1.使用File和FileStream两个类,FileStream负责读取数据的所以操作:(同步操作) var stream:FileStre ...