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等关键地方.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架