从log4net表中检索日志

时间:2013-07-17 05:39:11

标签: c# sql log4net

我使用log4net作为我的c#代码,使用配置

将日志插入数据库
<appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">
<bufferSize value="100" />
<connectionType value="System.Data.SqlClient.SqlConnection, 
System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<connectionString value="data source=[database server];
initial catalog=[database name];integrated security=false;
persist security info=True;User ID=[user];Password=[password]" />
<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>

所以我只需要使用他们的内置函数将数据插入表中。现在我需要从日志表中检索数据。 log4net是否提供从表中检索数据的任何功能?或者从这个表中检索数据的唯一方法是编写我自己的查询?有人请帮帮我。

2 个答案:

答案 0 :(得分:1)

我还没试过,但是简单的谷歌搜索让我得到http://code.google.com/p/log4net-db-viewer/和其他一些结果。 看起来任何appender都没有内置的阅读器。

答案 1 :(得分:1)

Log4net不会为您提供任何读取日志的工具。它只用于制作日志,它取决于appender格式化和保存日志。有许多项目和示例可以根据您的appender读取您的日志:

read log4net logs