zoukankan      html  css  js  c++  java
  • Log4net

    简介

    几乎所有的大型应用都会有自己的用于跟踪调试的API。因为一旦程序被部署以后,就不太可能再利用专门的调试工具了。然而一个管理员可能需要有一套强大的日志系统来诊断和修复配置上的问题。

    经验表明,日志记录往往是软件开发周期中的重要组成部分。它具有以下几个优点:它可以提供应用程序运行时的精确环境,可供开发人员尽快找到应用程序中的Bug;一旦在程序中加入了Log 输出代码,程序运行过程中就能生成并输出日志信息而无需人工干预。另外,日志信息可以输出到不同的地方(控制台,文件等)以备以后研究之用。

    Log4net就是为这样一个目的设计的,用于.NET开发环境的日志记录包。

    官方网站:http://logging.apache.org/log4net/

    使用方法

    第一步:Log4net的安装

    Install-Package log4net

    第二步:Log4net的配置

    log4net.config

    注意:将log4net.config的属性“复制到输出目录”设置为“始终复制”

    复制代码
    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
      <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
      </configSections>
      
      <log4net>
        <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
          <!--日志路径-->
          <param name= "File" value= "D:App_Log"/>
          <!--是否是向文件中追加日志-->
          <param name= "AppendToFile" value= "true"/>
          <!--log保留天数-->
          <param name= "MaxSizeRollBackups" value= "10"/>
          <!--日志文件名是否是固定不变的-->
          <param name= "StaticLogFileName" value= "false"/>
          <!--日志文件名格式为:2008-08-31.log-->
          <param name= "DatePattern" value= "yyyy-MM-dd&quot;.log&quot;"/>
          <!--日志根据日期滚动-->
          <param name= "RollingStyle" value= "Date"/>
          <layout type="log4net.Layout.PatternLayout">
            <param name="ConversionPattern" value="%d [%t] %-5p %c - %m%n %loggername" />
          </layout>
        </appender>
        
        <!-- 控制台前台显示日志 -->
        <appender name="ColoredConsoleAppender" type="log4net.Appender.ColoredConsoleAppender">
          <mapping>
            <level value="ERROR" />
            <foreColor value="Red, HighIntensity" />
          </mapping>
          <mapping>
            <level value="Info" />
            <foreColor value="Green" />
          </mapping>
          <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%n%date{HH:mm:ss,fff} [%-5level] %m" />
          </layout>
    
          <filter type="log4net.Filter.LevelRangeFilter">
            <param name="LevelMin" value="Info" />
            <param name="LevelMax" value="Fatal" />
          </filter>
        </appender>
    
        <root>
          <!--(高) OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL (低) -->
          <level value="all" />
          <appender-ref ref="ColoredConsoleAppender"/>
          <appender-ref ref="RollingLogFileAppender"/>
        </root>
      </log4net>
    </configuration>
    复制代码

    第三步:调用

    复制代码
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.IO;
    
    using log4net;
    using log4net.Config;
    
    namespace Log4net
    {
        class Program
        {
            static void Main(string[] args)
            {
                InitLog4Net();
    
                var logger = LogManager.GetLogger(typeof(Program));
    
                logger.Info("消息");
                logger.Warn("警告");
                logger.Error("异常");
                logger.Fatal("错误");
    
                Console.ReadLine();
            }
    
            private static void InitLog4Net()
            {
                var logCfg = new FileInfo(AppDomain.CurrentDomain.BaseDirectory + "log4net.config");
                XmlConfigurator.ConfigureAndWatch(logCfg);
            }
        }
    }
    复制代码

    深入理解Log4net的结构

    log4net 有四种主要的组件,分别是Logger(记录器), Repository(库), Appender(附着器)以及 Layout(布局).

    外部Blog资源:http://www.cnblogs.com/dragon/archive/2005/03/24/124254.html

    出处:http://www.cnblogs.com/jys509/p/4569874.html

    ==================================================================

    另外再推荐两个学习的地址:

    log4net使用详解

    Log4Net使用详解(续)

    =============================

    ==================================================================

    属性配置有两种写法:

    <appendToFile value="true" />
    <param name="appendToFile" value="true" />

    以上两种都是对的,看到的时候可以不用纠结这个。

    下面的是配置备份日志,当日志文件超过指定大小的时候,则自动备份,否则超过指定大小的时候Log4net回自动删除日志文件,重新记录。

        <appender name="LogicLog" type="log4net.Appender.RollingFileAppender">
          <file value="D:/LOG_TEST/Logic.log" />
          <datePattern value="yyyyMMdd-HH'.txt'"/>
          <appendToFile value="true" />
          <!--每个文件的大小,默认大小是10MB。只在混合方式与文件大小方式下使用,超出大小的在文件名后自动增加1重新命名-->
          <param name="maximumFileSize" value="8MB" />
          <!-- 最大备份的文件个数 -->
          <param name="MaxSizeRollBackups" value="7" />
          <!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])-->
          <param name="RollingStyle" value="Composite" />
          <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%date [%class %L] %-5p -%n%message%newline" />
          </layout>
        </appender>

    ==================================================================

  • 相关阅读:
    “回调地址”全攻略 java程序员
    超棒的纯Javascript实现的文件上传功能 Fine uploader java程序员
    帮助你操作数字和处理数字格式的javascript类库 Numeral.js java程序员
    正则表达式 java程序员
    一款非常棒的CSS 3D下拉式菜单实现Makisu java程序员
    Google的全新在线地图API演示网站 More than a map java程序员
    Android中的布局属性 java程序员
    整理一系列优秀的Android开发源码 java程序员
    Lambda表达式select()和where()的区别
    按公式产生随机数、java中的重载、递归、有关计算机计算的问题
  • 原文地址:https://www.cnblogs.com/mq0036/p/6351527.html
Copyright © 2011-2022 走看看