net Log4 Demo

1 篇文章 0 订阅

话不多说,直接看代码:

 准备工作:
http://logging.apache.org/,下载log4net(Net同胞别选错了,里面有面向不同开发语言的版本),最新为1.2版本,
建立一个.net web 项目,将log4net.dll添加到引用。

1:建立数据表
CREATE TABLE [dbo].[Log] (
[Id] [int] IDENTITY (1, 1) NOT NULL,
[Date] [datetime2] NOT NULL,
[Thread] [varchar] (255) NOT NULL,
[Level] [varchar] (50) NOT NULL,
[Logger] [varchar] (255) NOT NULL,
[Message] [varchar] (4000) NOT NULL,
[Exception] [varchar] (2000) NULL
)

2:编写配置文件
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>

<system.web>
<!--
......
-->
</system.web>

<log4net>

 <!--?日志书写设置加入运行-->

<root>

 <!--
<level value="ALL" />
<appender-ref ref="ADONetAppender" />

 -->
</root>

<logger name="testApp.Logging">
<level value="ALL"/>     

  <appender-ref ref="Loging" />

 <appender-ref ref="ErrorLoging" />

<appender-ref ref="ADONetAppender" />      

</logger>

 <!--?插入到数据库的日志-->

<appender name="ADONetAppender" type="log4net.Appender.ADONetAppender">
<bufferSize value="10" />
<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<connectionString value="server=localhost;database=demo;user id=sa;password=123456" />
<commandText value="INSERT INTO Log ([Date],[Thread],[Level],[Logger],[Message],[Exception]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
<parameter>
<parameterName value="@log_date" />
<dbType value="DateTime" />
<layout type="log4net.Layout.RawTimeStampLayout" />
</parameter>
<parameter>
<parameterName value="@thread" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%thread" />
</layout>
</parameter>
<parameter>
<parameterName value="@log_level" />
<dbType value="String" />
<size value="50" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%level" />
</layout>
</parameter>
<parameter>
<parameterName value="@logger" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%logger" />
</layout>
</parameter>
<parameter>
<parameterName value="@message" />
<dbType value="String" />
<size value="4000" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%message" />
</layout>
</parameter>
<parameter>
<parameterName value="@exception" />
<dbType value="String" />
<size value="2000" />
<layout type="log4net.Layout.ExceptionLayout" />
</parameter>
</appender>

   <appender name="Loging" type="log4net.Appender.RollingFileAppender,log4net" >

     <!--文件所在目录-->
      <param name="File" value="log/log.txt" />

     <!--追加文件-->
      <param name="AppendToFile" value="true" />

      <!--生成类型为每天每4MB一个文件-->
      <param name="RollingStyle" value="Composite" />

      <!--?以年月为分类文件夹名,以年月日_log为文件名称-->
      <param name="DatePattern" value="yyyyMMdd" />

      <!--?动态生成文件名称-->
      <param name="StaticLogFileName" value="true" />

      <!--?每个日志文件最大容量-->
      <param name="maximumFileSize" value="4MB"/>

       <!--?计数类型为正数0,1,2,3。。。-->
      <param name="CountDirection" value="1"/>

      <!--?日志输出格式-->
      <layout type="log4net.Layout.PatternLayout,log4net">
   <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss}%newline%message%n" />
        <param name="Header" value="&#13;&#10;" />
      </layout>

   <!--输出那些级别的日志-->
   <filter type="log4net.Filter.LevelRangeFilter">
              <param name="LevelMin" value="INFO" />
              <param name="LevelMax" value="INFO" />
       </filter>
    </appender>

 <!--?添加WINDOWS日志-->

<appender name="ErrorLoging" type="log4net.Appender.RollingFileAppender,log4net" >
      <param name="File" value="Err.txt" />
      <param name="AppendToFile" value="true" />
      <param name="RollingStyle" value="Date" />
      <param name="DatePattern" value="yyyyMMdd" />
      <param name="StaticLogFileName" value="true" />
 <!--日志输出格式-->     

 <layout type="log4net.Layout.PatternLayout,log4net">
   <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss}%newline%message%n" />
        <param name="Header" value="&#13;&#10;[Header]&#13;&#10;" />
        <param name="Footer" value="[Footer]&#13;&#10;" />
      </layout>

 <!--输出那些级别的日志-->
   <filter type="log4net.Filter.LevelRangeFilter">
              <param name="LevelMin" value="ERROR" />
              <param name="LevelMax" value="ERROR" />
       </filter>
    </appender>

 

</log4net>

</configuration>

特别说明<bufferSize value="10" />,这是log信息记录的缓冲大小,(比如只有log信息记录达到10,才会将log信息记录写入数据库)

config文件中红色字体的内容在下载的log4net项目中/doc/index.html中的config examples里面可以找到相应的。

做一个简单的封装,实现了常用的error日志和程序记录.
using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
using log4net;

 

namespace Log
{
    public static class Logger
    {
        private readonly static ILog logger = LogManager.GetLogger( "MyLogger" );
        static Logger()
        {

            //读取配置信息 
            log4net.Config.DOMConfigurator.Configure( new FileInfo( "log4net.config" ) );
        }

        public static void WriteErrMsg( Exception ex, string strModule, string strFunc )
        {
            logger.Error( strModule + "." + strFunc, ex );
        }

        public static void WriteErrMsg( string Message, string strModule, string strFunc )
        {
            logger.Error( strModule + "." + strFunc + "/r/n" + Message );
        }

        public static void WriteLog( string strMsg )
        {
            logger.Info( strMsg );
        }

        ......................................
    }

}

 

3:在Global.asax.cs中
protected void Application_Start(Object sender, EventArgs e)
{
//读取配置信息
log4net.Config.DOMConfigurator.Configure();
}


4:一个使用log的demo类
using System;

namespace Log
{
/// <summary>
/// MyLog 的摘要说明。
/// </summary>
public class MyLog
{
private static readonly log4net.ILog log = log4net.LogManager.GetLogger(typeof(MyLog));
public static void LogInfo()
{

log.Info("log日志");
}

public static void LogError()
{

//调用的日志类Logger
Logger.WriteLog("log错误");
}
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值