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. 1682: [Usaco2005 Mar]Out of Hay 干草危机

    1682: [Usaco2005 Mar]Out of Hay 干草危机 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 391  Solved: 258[ ...

  2. SDWebImage下载图片的使用

    第一步,下载SDWebImage,导入工程.github托管地址https://github.com/rs/SDWebImage 第二步,在需要的地方导入头文件 1 #import "UII ...

  3. ST HW3

    7. Use the following method printPrimes() for questions a-f below. /******************************** ...

  4. Jmeter函数引用和函数重定向

    在jmeter中的[选项]中选择[函数助手对话框]---这些函数可以高速有效的帮助我们开展自动化编写与校验!!!!!! 如图: 重点!!!本章的侧重点不讲函数的具体使用,函数具体的使用与java类似, ...

  5. Android之XListView下拉刷新,更新网络美女图

    一.简介:   下拉刷新是一种特定的手动刷新交互,和其他的同类操作不同的地方在于它采用了更加直觉的下拉操作,所以它的交互足够清晰明显. 下拉刷新主要用在类似ListView这样的控件,设计下拉刷新有三 ...

  6. 通过composer管理工具安装laravel

    当安装好composer管理工具后,将composer的bin目录添加至环境变量中(PATH),方便在任意目录下执行composer命令. 方法1:我们通过laravel工具安装laravel 首先, ...

  7. centos6.5用tomcat安装jenkins

    1下载jdk并安装配置环境变量 # cd /opt/app # .0_45.tar.gz # vi /etc/profile JAVA_HOME=/opt/app/jdk1..0_45 CLASSPA ...

  8. bootstrap-typeahead自动补充

    官方文档:https://github.com/bassjobsen/Bootstrap-3-Typeahead 这个是基于bootstrap的typeahead与基于jquery的jquery-Ty ...

  9. 20155237 2016-2017-2 《Java程序设计》第5周学习总结

    20155237 2016-2017-2 <Java程序设计>第5周学习总结 教材学习内容总结 语法与继承架构 使用try...catch 与C语言中程序流程和错误处理混在一起不同,Jav ...

  10. JavaScript高级程序设计---学习笔记(二)

    面向对象程序设计1.属性类型.定义多属性.读取属性特性对象的属性在创建时都带有一些特征值,JavaScript通过这些特征值来定义它们的行为.这些特性是为了实现JavaScript引擎用的,因此不能直 ...