zoukankan      html  css  js  c++  java
  • log4NET学习

      1  毕业一年了,想起刚毕业那会所做的事 有点好笑。。。。

          由于项目经理之前是用VB的,刚好要把项目的代码全转为C#,所以碰上了这个很好的机会,但工资低得可怜,抱着刚毕业主要是学习为主的心态,开始了我的职业生涯。

          首先是从C#里最基本的模块做起,读取INI 读取XML,日志处理,数据库操作等等,这差不多做了一二个月吧,

        其它这些基本的东西网上到处是,当时就没想过这么多,只是找过一些思路。真可谓 此情可待成追忆,只是当时已惘然。

      如果从网上找这些对应的开源,不到一周就基本上能搞好了,真是浪费人力,浪费工资。

          后面就把GIS里的模块用C#写了一遍,这对换工作是极有用的。

     基本的数据管理,配置管理,视图操作,查询模块,分析,统计等模块。

         日志处理并不是一个很简单的事情,当你有了Log4NET后就大可不必担心了,来看看如何快速的使用它吧。。

    首先需要配置相关的配置文件App.config或Web.config,顾名思义普通应用的配置文件

    为App.config,asp.net的配置文件为Web.config。有关log的配置如下:

    <configuration>

       <configSections>

           <!-- log4net的定义 -->

             <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />

       </configSections>

       <log4net>

       <!-- Console部分log输出格式的设定 -->

             <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">

                 <layout type="log4net.Layout.PatternLayout">

                     <conversionPattern value="%date [%thread] %-5level %logger %ndc - %message%newline" />

                 </layout>

             </appender>

       <!-- 日志文件部分log输出格式的设定 -->

             <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">

                 <file value="c:\a.log" />

                 <appendToFile value="true" />

                 <maxSizeRollBackups value="10" />

                 <maximumFileSize value="1MB" />

                 <rollingStyle value="Size" />

                 <staticLogFileName value="true" />

                 <layout type="log4net.Layout.PatternLayout">

                     <header value="[Header] " />

                     <footer value="[Footer] " />

                     <ConversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" />

                 </layout>

             </appender>

      

       <!-- Setup the root category, add the appenders and set the default level -->

             <root>

                 <level value="ALL" />

                 <appender-ref ref="ConsoleAppender" />

                 <appender-ref ref="RollingLogFileAppender" />

             </root>

         </log4net>

    </configuration>

     

     

    其次在项目的AssemblyInfo.cs里面加上[assembly: log4net.Config.XmlConfigurator()],这样项目工程和log4net就

    建立了关联。

    备注:[assembly: log4net.Config.DOMConfigurator()]这句话的意思是log4net系统会自动寻找配置文件App.config或Web.config

    从而获得并加载其中的配置信息。如果想log4net随时监视配置文件以便重新加载的话就要这样写:

    [assembly:log4net.Config.DOMConfigurator(ConfigFile="filename",ConfigFileExtension="log4net",Watch=true)]

    最后就是源文件中的使用了。

    添加log4net的引用using log4net;

    同时在相关的类中定义log变量如

       protected static readonly log4net.ILog mLog =

        LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

    log的具体操作,Form1中加入了:

    如mLog.Error("ha ha log4NET");

     

     

    找下你的C盘,里面的 c:\a.log吧

    [Header] 2009-08-21 09:31:52,140 [10] ERROR Test.Form1 [(null)] - ha ha log4NET

     

     

    怎么样?很方便吧,,之前写日志处理都 不知道花了多少时间,太爽了。。

  • 相关阅读:
    在cmd中登录ftp服务器
    Is valid identifier?
    Hosting Your Own NuGet Feeds
    NuGet学习笔记
    软件版本的处理
    有些事明显对自己有益,为什么却无法去做?
    .net 程序员成长路线图?
    正确跑步姿势是怎样的?
    什么叫做内心强大?怎样变成一个内心强大的人?
    使用命令行复制目录
  • 原文地址:https://www.cnblogs.com/lhjhl/p/1551171.html
Copyright © 2011-2022 走看看