在ASPNET 中可以使用healthMonitoring属性监测事件healthMonitoring属性是一个基于方法的provider在这里可以构造自己的provider利用healthMonitoring属性我们可以诸如记录错语成功的事件等对不同的数据源如事件日志Sql Server甚至对于自己通过继承WebEventProvider类创建自己的providers在此文章中我打算介绍配置一个监测SqlServer错语的并且对某人的电子信箱地址发送邮件的web应用程序首先看一下在nfig中的healthMonitoring程序片段在此可以建立将要用到的事件
<healthMonitoring Enabled=true|false heartBeatInterval=time interval>
<bufferModes> </bufferModes>
<providers> </providers>
<eventMappings> </eventMappings>
<profiles> </profiles>
<rules> </rules>
</healthMonitoring>
如果看一下<healthMonitoring>元素就可以判断是否可以将设置属性为有效或无效也可以指定对WebHeaderBeatEvent被唤醒的时间间隔healthMonitoring有个孩子
bufferModes在此可以定义一个Provider的缓沖区大小
Providers在此说明处理事件的Providers
eventMappings 在此可以画出与友好事件类型相关的事件名称
profiles 在此定义一个可以用来配置事件的参数集集合
rules 在此画出Providers的事件图
可以阅读更多含在VS 文档中的关于这些元素的东西
在继续之前这里有一份含ASPNET中的一些Providers清单
SystemWebManagementMailWebEventProvider
SystemWebManagementSimpleMailWebEventProvider
SystemWebManagementTemplatedMailWebEventProvider
SystemWebManagementTraceWebEventProvider
SystemWebManagementEventLogWebEventProvider
SystemWebManagementSqlWebEventProvider
SystemWebManagementWmiWebEventProvider
不需要解释这些名字告诉我们它们是干什么的还要提一下SqlWebEventProvider依靠Sql server而工作它将事件存储在aspnet_Web_Event表为了安装此数据库必须运行位于framework文件夹中的aspnet_regsqlexe向导
现在配置对Sql server provider有登录错语并且发送一个电子邮件而产生错误的程序
下面是一个使用SqlWebEventProvider和SimpleMailWebEventProvider来存错语事件的例子
<healthMonitoring enabled=true heartBeatInterval=>
<bufferModes>
<add name=Critical Notification maxBufferSize= maxFlushSize=urgentFlushThreshold= regularFlushInterval=Infinite urgentFlushInterval=:: maxBufferThreads=/>
<add name=Analysis maxBufferSize= maxFlushSize= urgentFlushThreshold=
regularFlushInterval=:: urgentFlushInterval=:: maxBufferThreads=/>
</bufferModes>
<providers>
<add name=CriticalMailEventProvider type=SystemWebManagementSimpleMailWebEventProvider SystemWeb from= to= priority=High bodyHeader=Warning!
bodyFooter=Please investigate ASAP subjectPrefix=Action required buffer=true bufferMode=Critical Notification maxEventLength= maxSize= maxMessagesPerNotification=/>
<add name=SqlWebEventProvider type=SystemWebManagementSqlWebEventProvider SystemWeb
connectionStringName=LocalSqlServer maxEventDetailsLength= buffer=true
bufferMode=Analysis/>
</providers>
<eventMappings>
<add name=All Errors type=SystemWebManagementWebBaseErrorEvent SystemWeb />
<add name=Request Processing Errors type=SystemWebManagementWebRequestErrorEvent SystemWeb />
</eventMappings>
<profiles>
<add name=Default minInstances= maxLimit=Infinite minInterval=::/>
</profiles>
<rules>
<add name=All Errors Default eventName=All Errors provider=SqlWebEventProvider profile=Default
minInterval=::/>
<add name=Request Processing Errors eventName=Request Processing Errors provider=CriticalMailEventProvider profile=Default/>
</rules>
</healthMonitoring>
在此例子中使用Sql provider来记录所有错语事件并且当Web请求错误事件被唤醒时使用mail provider来发送一个消息
这里有一些ASP NET 一起发布的事件
SystemWebManagementWebBaseEvent
SystemWebManagementWebHeartBeatEvent
SystemWebManagementWebApplicationLifetimeEvent
SystemWebManagementWebRequestEvent
SystemWebManagementWebBaseErrorEvent
SystemWebManagementWebErrorEvent
SystemWebManagementWebRequestErrorEvent
SystemWebManagementWebAuditEvent
SystemWebManagementWebFailureAuditEvent
SystemWebManagementWebSuccessAuditEvent
SystemWebManagementWebManagementEvent
SystemWebManagementWebViewStateFailureAuditEvent
SystemWebManagementWebAuthenticationFailureAuditEvent
SystemWebManagementWebAuthenticationSuccessAuditEvent
可以使用这些事件来对一个provider画图也可以创建通过WebBaseEvent类继承来的自己的事件
为自动唤醒一个事件可以使用WebBaseEvent类的唤醒方法
try
{
//
}
catch(Exception e)
{
if (HealthMonitoringManagerEnabled)
{
WebBaseEventRaise(new WebErrorEvent(My Error message null e));
}
}
or:
if (HealthMonitoringManagerEnabled)
{
WebErrorEvent event = new WebErrorEvent(My error message null e);
eventRaise();
}