您现在的位置: 中国男护士网 >> 考试频道 >> 计算机等级 >> 二级辅导 >> C语言 >> 辅导 >> 正文    
  C#实现SQLServer数据库日志的配置方法 【注册男护士专用博客】          

C#实现SQLServer数据库日志的配置方法

www.nanhushi.com     佚名   不详 

在数据库中准备一个这样的表,mail_web_log:
生成脚本:
 
CREATE TABLE [dbo].[mail_web_log] (
   [nId] [int] IDENTITY (1, 1) NOT NULL ,
    [dtDate] [datetime] NOT NULL ,
    [sThread] [varchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,
    [sLevel] [varchar] (200) COLLATE Chinese_PRC_CI_AS NOT NULL ,
    [sLogger] [varchar] (200) COLLATE Chinese_PRC_CI_AS NOT NULL ,
    [sMessage] [varchar] (2000) COLLATE Chinese_PRC_CI_AS NOT NULL ,
    [sException] [varchar] (4000) COLLATE Chinese_PRC_CI_AS NULL
) ON [PRIMARY]
GO


ALTER TABLE [dbo].[mail_web_log] WITH NOCHECK ADD
    CONSTRAINT [PK_mail_web_log] PRIMARY KEY  CLUSTERED
    (
        [nId]
    )  ON [PRIMARY]
GO
 
其中,sLevel字段代表日志的级别;sLogger字段代表日志是由哪一个类或者文件产生的,如
“iNotes.Default.Page_Load(c:\mail\mailsource\default.aspx.cs:269)”;sMessage字段代表日志的内容。
Web.config中Log.Net的配置
注意其中“AD.NetAppender”节点的写法,以及各个字段的打印方法。
一般来说,我们对每一个日志字段定义一个“<Layout type="log.Net.Layout.PatternLayout">”节点以告诉log.Net如何输出,在这个节点之下,我们需要配置
<conversionPattern value="%t" />
%t在log.Net中专门指的是线程名。
下面我们对“%d %t %p %l %m %n”一一讲解:
l         %d输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy-MM-dd HH:mm:ss},输出类似:2005-7-19 17:49:27,刚好适合插入SQLServer;
l         %t  产生该日志事件的线程名;
l         %p 日志的log_level,如DEBUG、WARN或者INFO;
l         %c  输出所属的类目,通常就是所在类的全名,如“iNotes.Default”;
l         %m 日志的内容;
l         %l  输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。如write2database.main(write2database.Java:33);
%n  输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”


对于web站点的web.config文件,需要如下配置,这部分是参考了.Net/user/cgq214">cgq214 的Blog讲到的写法,同时根据实际效果作了点修正:
配置:
 
<log.Net>

<appender name="AD.NetAppender" type="log.Net.Appender.AD.NetAppender">
                    <bufferSize value="10" />
                    <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
                    <connectionString value="server=192.168.1.112;database=domino;uid=sa;pwd=;timeout=300;" />
                    <commandText value="INSERT INTO mail_web_log ([dtDate],[sThread],[sLevel],[sLogger],[sMessage],[sException]) VALUES (@log_date, @thread, @log_level, @logger, @message, @exception)" />
                    <parameter>
                        <parameterName value="@log_date" />
                        <dbType value="DateTime" />
                        <layout type="log.Net.Layout.RawTimeStampLayout" />
                    </parameter>
                    <parameter>
                        <parameterName value="@thread" />
                        <dbType value="String" />
                        <size value="50" />
                        <layout type="log.Net.Layout.PatternLayout">
                            <conversionPattern value="%t" />
                        </layout>                  
                    </parameter>
                    <parameter>
                        <parameterName value="@log_level" />
                        <dbType value="String" />
                        <size value="200" />
                        <layout type="log.Net.Layout.PatternLayout">
                            <conversionPattern value="%p" />
                        </layout>
                    </parameter>
                    <parameter>
                        <parameterName value="@logger" />
                        <dbType value="String" />
                        <size value="200" />
                        <layout type="log.Net.Layout.PatternLayout">
                            <conversionPattern value="%logger" />
                        </layout>
                    </parameter>
                    <parameter>
                        <parameterName value="@message" />
                        <dbType value="String" />
                        <size value="2000" />
                        <layout type="log.Net.Layout.PatternLayout">
                            <conversionPattern value="%m" />
                        </layout>
                    </parameter>
                    <parameter>
                        <parameterName value="@exception" />
                        <dbType value="String" />
                        <size value="2000" />
                        <layout type="log.Net.Layout.ExceptionLayout" />
                    </parameter>
                </appender>
       
        <!-- Setup the root category, add the appenders and set the default level -->
        <root>
            <level value="WARN"/>
            <level value="INFO"/>
            <level value="DEBUG"/>
            <level value="FINE"/>
        </root>
        <!-- Specify the level for some specific categories -->
        <logger name="iNotes">
            <level value="WARN"/>
            <level value="INFO"/>
            <level value="DEBUG"/>
            <level value="FINE"/>
            <appender-ref ref="RollingLogFileAppender"/>
            <appender-ref ref="AD.NetAppender" />
        </logger>
    </log.Net>

 

文章录入:杜斌    责任编辑:杜斌 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
     

    联 系 信 息
    QQ:88236621
    电话:15853773350
    E-Mail:malenurse@163.com
    免费发布招聘信息
    做中国最专业男护士门户网站
    最 新 热 门
    最 新 推 荐
    相 关 文 章
    没有相关文章
    专 题 栏 目