2013-03-20 72 views
7

當前在我的項目log4net用於記錄所有的異常,信息,警告等文本文件,但現在我想要的是將所有這些細節記錄到數據庫表而不是文件。
請幫我做到這一點。如何使用Log4Net工具登錄到數據庫使用c#

非常感謝提前。

配置:

<log4net> 
    <root> 
    <level value="DEBUG" /> 
    <appender-ref ref="ADONetAppender" /> 
    </root> 
    <appender name="ADONetAppender" type="log4net.Appender.ADONetAppender"> 
    <bufferSize value="100" /> 
    <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" /> 
    <connectionString value="server=xxxx; uid=xxxx; pwd=xxxx; database=xxxx" /> 
    <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> 

代碼在cs文件:

private log4net.ILog log = log4net.LogManager.GetLogger(typeof(ImportGlobalIPVData)); 
log.Error("This is Error"); 

但沒有得到使用上面的代碼後插入日誌表。

+2

這肯定之前已經做過很多次(之前記錄很多次)。也許你可能會描述你試過的東西以及爲什麼你被困住了。 – Reddog 2013-03-20 06:18:00

+0

可以請您分享我可以從哪裏獲得詳細信息的鏈接,因爲我之前從未使用過log4net。 – 2013-03-20 06:19:59

+0

如果是SQLServer的,有在計算器上一個例子吧[這裏](http://stackoverflow.com/questions/3279524/storing-log4net-messages-in-sql-server)。 – nvoigt 2013-03-20 06:26:54

回答

4

你可以看看here,我想這正是你需要的。

請注意,如果您想從客戶端應用程序使用log4net並寫入數據庫,則可能需要考慮在兩者之間放置服務。在這種情況下,您可以輕鬆編寫自己的log4net適配器,該適配器調用登錄到數據庫(可能使用MSMQ)的LogService(fire and forget)。

+0

是的,從這個鏈接只有我能夠配置我的代碼將日誌寫入數據庫,但我注意到日誌表沒有立即反映日誌的條目,是否有任何設置立即反映表中的日誌? – 2013-03-20 09:22:14

+0

我注意到一個更奇怪的行爲,當我保存global.asax文件的所有條目的日誌在表中可見時,我不知道global.asax文件和數據庫之間的連接是什麼? – 2013-03-20 09:32:23

+4

我得到了解決方案,因爲我在配置中使用了<',這就是爲什麼log不會立即插入到表中。我將它改爲'',我的問題就解決了。謝謝大家的控制 – 2013-03-21 06:39:10