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. PDO(20161107)

    PDO MySQLI是针对MySQL数据库扩展的,是专门访问MySQL数据库的 PDO是一个数据库访问的一个扩展类,通过一个类访问多个数据库,就是一个数据访问抽象层,把类结合在一块了 可以访问别的数据 ...

  2. (102, "Incorrect syntax near '-'.DB-Lib error message 102, severity 15:\nGen

    python 调用MSSQL存储过程,运行时报错 sql="exec spname %s,%s"%(param1,param2) 这是错误的调用存储过程的语句,param1和par ...

  3. 关于如何介绍spring框架。

    一.介绍Spring 1.Spring是一个分层的JavaSE/EEfull-stack(一站式) 轻量级开源框架. 2.概念:轻量级的IOC(控制反转或者依赖注入).AOP(面向切面或者面向方面) ...

  4. Java第一次作业

    (一)学习总结 1.在java中通过Scanner类完成控制台的输入,Scanner类实现基本数据输入的方法是什么? import java.util.Scanner; System.out.prin ...

  5. MVC不用302跳转Action,内部跳转

    原理,在一个Action里面return 另一个Action出去. public class HomeController : Controller { // GET: Home public Act ...

  6. SSH里面使用jQuery的ajax

    今天我真的很兴奋!在我的SSH项目中用jQuery的异步传输成功了,经过一天多的奋战,大工告成! 我的项目需求是在javascript中向我的controller(即:action)中传输form表单 ...

  7. JavaScript对象原型写法区别

        体现对象原型分步式写法 //原型分步式写法 //构造函数 function Person(){} //对象原型 Person.prototype.name = 'Avensatr'; Pers ...

  8. Nginx网站使用CDN之后禁止用户真实IP访问的方法

    做过面向公网WEB的运维人员经常会遇见恶意扫描.拉取.注入等图谋不轨的行为,对于直接对外的WEB服务器,我们可以直接通过 iptables .Nginx 的deny指令或是程序来ban掉这些恶意请求. ...

  9. 【canvas系列】canvas实现"雷达扫描"效果

    今天来讲解"雷达扫描"效果demo,来源于QQ群里边有群友说想要个雷达效果,就尝试写了一下. 效果图: demo链接: https://win7killer.github.io/c ...

  10. Terminating app due to uncaught exception 'NSUnknownKeyException' this class is not key value coding-compliant for the key

     Terminating app due to uncaught exception 'NSUnknownKeyException', reason: '[ViewController > se ...