在ASP.NET 2.0中,可以使用healthMonitoring屬性監測事件。 healthMonitoring屬性是一個基於方法的provider,在這裡可以建構自己的provider。利用healthMonitoring屬性,我們可以諸如記錄錯語、成功的事件等,對不同的資料來源,如事件日誌,Sql Server甚至對於自己透過繼承WebEventProvider類別來建立自己的providers。在這篇文章中,我打算介紹配置一個監測SqlServer錯語的並且對某人的電子信箱地址發送郵件的web應用程式。首先,先來看看在web.config中的healthMonitoring程式片段,在此可以建立將要用到的事件。
<healthMonitoring Enabled="true|false" heartBeatInterval="time interval">
<bufferModes>... </bufferModes>
<providers>... </providers>
<eventMappings>... </eventMappings>
<profiles>... </profiles>
<rules>... </rules>
</healthMonitoring>
如果看一下<healthMonitoring>元素,就可以判斷是否可以將設定屬性為有效或無效,也可以指定對WebHeaderBeatEvent被喚醒的時間間隔。 healthMonitoring有5個孩子。
bufferModes,在此可以定義一個Provider的緩衝區大小。
Providers,在此說明處理事件的Providers。
eventMappings, 在此可以畫出與友善事件類型相關的事件名稱。
profiles, 在此定義一個可以用來配置事件的參數集集合。
rules, 在此畫出Providers的事件圖。
可以閱讀更多含在VS 2550文件中的關於這些元素的東西。
在繼續之前,這裡有一份包含ASP.NET中的一些Providers清單:
System.Web.Management.MailWebEventProvider
System.Web.Management.SimpleMailWebEventProvider
System.Web.Management.TemplatedMailWebEventProvider
System.Web.Management.TraceWebEventProvider
System.Web.Management.EventLogWebEventProvider
System.Web.Management.SqlWebEventProvider
System.Web.Management.WmiWebEventProvider
不需要解釋這些,名字告訴我們它們是做什麼的。也提一下SqlWebEventProvider依賴Sql server而工作,它將事件儲存在aspnet_Web_Event表。為了安裝此資料庫,必須執行位於framework資料夾中的aspnet_regsql.exe精靈。
現在,設定對Sql server provider有登入錯語並且發送一個電子郵件而產生錯誤的程式。
以下是一個使用SqlWebEventProvider和SimpleMailWebEventProvider來存錯語事件的範例。
<healthMonitoring enabled="true" heartBeatInterval="0">
<bufferModes>
<
add name="Critical Notification" maxBufferSize="100" maxFlushSize="20"urgentFlushThreshold="1" regularFlushInterval="Infinite" urgentFlushInterval="00:01:00" maxBufferThreads="1"/add
" maxBufferSize="1000" maxFlushSize="100" urgentFlushThreshold="100"
regularFlushInterval="00:05:00" urgentFlushInterval="00:01:00" maxBufferThreads="1"/>
</bufferModes>
<providers>
<add name="CriticalMailEventProvider" type="System.Web.Management.SimpleMailWebEventProvider, System.Web ..." [email protected] [email protected] priority="High" bodyHeader=" Warning!"
bodyFooter="Please investigate ASAP." subjectPrefix="Action required." buffer="true" bufferMode="Critical Notification" maxEventLength="4096" maxSize="4096" maxMessaPerNotification="1"/>
<Webadd name="SlWebgesProviderq" type="System.Web.Management.SqlWebEventProvider, System.Web ..."
connectionStringName="LocalSqlServer" maxEventDetailsLength="1073741823" buffer="true"
bufferMode="Analysis"/>
</providers>
<eventMappings>
<add name="All Errors" type="System.Web.Management.WebBaseErrorEvent, System.Web ..."/>
<add name="Request Processing Errors" type="System.Web.Management.WebRequestErrorEvent, System.Web .../>
</eventMappings>
<profiles>
<add name="Default" minInstances="1" maxLimit=" Infinite" minInterval="00:10:00"/>
</profiles>
<rules>
<add name="All Errors Default" eventName="All Errors" provider="SqlWebEventProvider" profile="Default"
minInterval="00:00:30"/>
<add name="Request Processing Errors" eventName="Request Processing Errors" provider="CriticalMailEventProvider" profile="Default"/>
</rules>
</healthMonitoring>
在此範例中,使用Sql provider來記錄所有錯語事件,並且當Web請求錯誤事件被喚醒時使用mail provider來傳送一個訊息。
這裡有一些ASP .NET 2.0一起發佈的事件:
System.Web.Management.WebBaseEvent
System.Web.Management.WebHeartBeatEvent
System.Web.Management.WebApplicationLifetimeEvent
System.Web.Management.WebRequestEvent
System.Web.Management.WebBaseErrorEvent
System.Web.Management.WebErrorEvent
System.Web.Management.WebRequestErrorEvent
System.Web.Management.WebAuditEvent
System.Web.Management.WebFailureAuditEvent
System.Web.Management.WebSuccessAuditEvent
System.Web.Management.WebManagementEvent
System.Web.Management.WebViewStateFailureAuditEvent
System.Web.Management.WebAuthenticationFailureAuditEvent
System.Web.Management.WebAuthenticationSuccessAuditEvent
可以使用這些事件來為一個provider繪製圖片。也可以建立透過WebBaseEvent類別繼承來的自己的事件。
為自動喚醒事件,可以使用WebBaseEvent類別的喚醒方法:
try
{
//....
}
catch(Exception e)
{
if (HealthMonitoringManager.Enabled)
{
WebBaseEvent.Raise(new WebErrorEvent("My Error message", null, 5000, e));
}
}
or:
if (HealthMonitoringManager.Enabled)
{
WebErrorEvent event = new WebErrorEvent("My error message", null, 5000, e);
event.Raise();
}