zoukankan      html  css  js  c++  java
  • Log4Net AdoNetAppender配置方法(数据库记录配置方法)

    以下是在基于Log4net的基本配置的基础之上配置数据库

    Log4net基本配置可以参考: http://www.cnblogs.com/Flyear/archive/2009/03/16/1412933.html

    第一步: 在log4net的配置文件(log4net.config)中新建立一个Appender

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

    // Access DataBase Config Start
          <!--<connectionString value="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\access.mdb" />-->

    // Access DataBase Config End


          <bufferSize value="1" />
          <!--设置为1方便查看结果,处于性能考虑这里的值应该略大一点,官方默认值是100-->

    // MSSQL DataBase Config Start
          <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
          <connectionString value="data source=(local);DataBase=AccessStatistic;User Id=sa;Password=sa" />

    // MSSQL DataBase Config End


          <commandText value="INSERT INTO SystemLog ([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>

    第二步: 将LogAppender 绑定到Logger

    <logger name="DBEXECUTEERROR">
          <level value ="ALL"/>
          <appender-ref ref="AdoNetAppender" />     
        </logger>
      </log4net>

    第三步: 测试

    注意事项:

          输出到数据库的时候, 如果遇到错误Log4net是不会把异常抛到我们的程序当中的, 所以你用Try..Catch是捕捉不到Log4net的异常(这个非官方说明,是我自己测试的,

     有不同意见的朋友补充一下), 所以在配置的时候要仔细查看connectionstring , Insert Sql等关键地方.

  • 相关阅读:
    BZOJ5194: [Usaco2018 Feb]Snow Boots(排序&set)(可线段树优化)
    BZOJ5280: [Usaco2018 Open]Milking Order(二分+拓扑)
    BZOJ5281: [Usaco2018 Open]Talent Show(01分数规划&DP)
    BZOJ4837:[Lydsy1704月赛]LRU算法(双指针&模拟)
    【NOIP2013】传染病控制
    bzoj 2754: [SCOI2012]喵星球上的点名
    bzoj 4197: [Noi2015]寿司晚宴
    Codeforces Round #438 B. Race Against Time
    Codeforces Round #438 C. Qualification Rounds
    Codeforces Round #438 D. Huge Strings
  • 原文地址:https://www.cnblogs.com/feinian/p/1415288.html
Copyright © 2011-2022 走看看