专栏首页拂晓风起Log4Net ,.net和SQL Server的完美结合

Log4Net ,.net和SQL Server的完美结合

不过,我在我这个项目中,具体使用的方法有点不同。

这个学生处学生信息管理系统,业务日志比较简单,其实并不需要使用log4net。所以在这个项目中,只用log4net来记录错误日志。

1.建立配置文件。以下配置,是把信息记录到数据库和一个以当前日期为名字的日志txt文件。从数据库的insert语句就可以看出数据库的

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
    </configSections>
  <log4net>
    <appender name="ADONetAppender" type="log4net.Appender.AdoNetAppender">
      <bufferSize value="1" />
      <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
      <connectionString value="server=codebase;database=StuDepartmentOA;uid=sadis;pwd=123;timeout=300;" />
      <commandText value="INSERT INTO ErrLog ([Time],[errLevel],[Info],[Exception]) VALUES (@time, @level, @info, @exception)" />
      <parameter>
        <parameterName value="@time" />
        <dbType value="DateTime" />
        <layout type="log4net.Layout.RawTimeStampLayout" />
      </parameter>
      <parameter>
        <parameterName value="@level" />
        <dbType value="String" />
        <size value="8" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%p" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@info" />
        <dbType value="String" />
        <size value="200" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%m" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@exception" />
        <dbType value="String" />
        <size value="1000" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%exception" />
        </layout>
      </parameter>
    </appender>
    <appender name="FileErrLogAppender" type="log4net.Appender.RollingFileAppender">
      <!--日志文件的存储路径-->
      <file value="bin\Log\"/>
      <appendToFile value="true"/>
      <rollingStyle value="Date"/>
      <datePattern value="yyyy-MM-dd.LOG"/>
      <!--根据日期,定义文件名-->
      <staticLogFileName value="false"/>
      <!--日志文件输出格式-->
      <layout  type="log4net.Layout.PatternLayout">
        <param name="Header" value="[Header]"/>
        <param name="Footer" value="[Footer]"/>
        <ConversionPattern value="%nTime: %d %n Level: %level   Info: %message %nException: %exception"/>
      </layout>
    </appender>
    <!-- Setup the root category, add the appenders and set the default level -->
    <root>
      <level value="WARN"/>
      <level value="INFO"/>
      <level value="DEBUG"/>
    </root>
    <!-- Specify the level for some specific categories -->
    <logger name="logger">
      <level value="WARN"/>
      <level value="INFO"/>
      <level value="DEBUG"/>
      <appender-ref ref="FileErrLogAppender"/>  
      <appender-ref ref="ADONetAppender" />
    </logger>
  </log4net>
</configuration>

对应的数据库表:

USE [StuDepartmentOA]
GO
/****** 对象:  Table [dbo].[ErrLog]    脚本日期: 08/16/2009 10:09:31 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_PADDING ON
GO
CREATE TABLE [dbo].[ErrLog](
    [ID] [int] IDENTITY(1,1) NOT NULL,
    [time] [datetime] NOT NULL,
    [errLevel] [varchar](8) COLLATE Chinese_PRC_CI_AS NOT NULL,
    [info] [nvarchar](200) COLLATE Chinese_PRC_CI_AS NOT NULL,
    [exception] [varchar](1000) COLLATE Chinese_PRC_CI_AS NULL,
 CONSTRAINT [PK_errLog] PRIMARY KEY CLUSTERED 
(
    [ID] ASC
)WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY]
GO
SET ANSI_PADDING OFF

2.把配置文件放到Web目录下,跟web.config同一层。

3.建立globe.asax文件,在Application_Start中加入

log4net.Config.XmlConfigurator.ConfigureAndWatch(new System.IO.FileInfo(Server.MapPath("~") + @"\log4net.config"));

4.再加入相应的引用。然后如果项目中有其他类库,那么再在对应用到的类库中加入引用。

(!!这里需要注意的是,如果用了NHibernate,就需要注意了,必须加入对应版本的log4net,不然会出错。我本来加了一个1.2.9的log4net,但NHibernate默认用附带的1.2.10,运行时就报错了)

5.实际使用:

using System;
using log4net;
namespace DAL
{
    /// <summary>
    /// LogHelper 的摘要说明
    /// </summary>
    public class LogHelper
    {
        private static ILog Logger = log4net.LogManager.GetLogger("logger");
        public static void Debug(string message, Exception ex)
        {
            if(Logger.IsDebugEnabled)
            {
                Logger.Debug(message, ex);
            }
        }
        public static void Debug(string message)
        {
            if (Logger.IsDebugEnabled)
            {
                Logger.Debug(message);
            }
        }
        public static void Info(string message, Exception ex)
        {
            if(Logger.IsInfoEnabled)
            {
                Logger.Info(message, ex);
            }
        }
        public static void Info(string message)
        {
            if (Logger.IsInfoEnabled)
            {
                Logger.Info(message);
            }
        }
        public static void Error(string message, Exception ex)
        {
            if (Logger.IsErrorEnabled)
            {
                Logger.Error(message,ex);
            }
        }
        public static void Error(string message)
        {
            if (Logger.IsErrorEnabled)
            {
                Logger.Error(message);
            }
        }
    }
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • [C#]log4net写SQLServer数据库日志的配置方法

    用户1258909
  • java poi读取excel公式,返回计算值

    用户1258909
  • Django: "No module named urls" error for /admin/

    用户1258909
  • 什么,你算出的P-value看上去像齐天大圣变的庙?

    前几天,Nature上一篇comment再度引发关于p-value如何使用和解释的文章:Scientists rise up against statistic...

    生信宝典
  • 大众点评App的短视频耗电量优化实战

    前言 美团点评测试团队负责App的质量保证工作,日常除了App的功能测试以外,还会重点关注App的性能测试。现在大家对手机越来越依赖,而上面各App的耗电量,直...

    美团技术团队
  • 高流量站点NGINX与PHP-fpm配置优化

    使用Nginx搭配PHP已有7年的这份经历让我们学会如何为高流量站点优化NGINX和PHP-fpm配置。 以下正是这方面的一些提示和建议: 1. 将TCP切换为...

    小小科
  • 排序算法-冒泡排序

    排序算法-冒泡排序 <?php /** * 冒泡排序 * * @param array $value 待排序数组 * * @return array...

    琯琯
  • 关于 python 中使用 lambda 表达式的问题

    --------------------------------  def doLambda(val):   print "value 2:", val ...

    田春峰-JCJC错别字检测
  • lodash 是如何做类型检测的

    JS 的基本数据类型有 Number,String,Boolean,Symbol,Null,Undefined,六种数据类型。一种引用类型 object。

    Javanx
  • AppScan安全漏洞说明及解决方案

    解决方案:向所有会话cookie 添加HttpOnly属性 ,可以在过滤器中统一添加。

    java乐园

扫码关注云+社区

领取腾讯云代金券