WebManagementEvent 类
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
定义承载应用程序和进程信息的事件的基类。
public ref class WebManagementEvent : System::Web::Management::WebBaseEvent
public class WebManagementEvent : System.Web.Management.WebBaseEvent
type WebManagementEvent = class
inherit WebBaseEvent
Public Class WebManagementEvent
Inherits WebBaseEvent
- 继承
- 派生
示例
以下示例演示如何通过从 WebManagementEvent 类派生自定义事件来实现自定义事件。
using System;
using System.Text;
using System.Web;
using System.Web.Management;
namespace Samples.AspNet.Management
{
// Implements a custom
// WebManagementEvent class.
public class SampleWebManagementEvent :
WebManagementEvent
{
private StringBuilder eventInfo;
// Invoked in case of events
// identified only by their event code.
public SampleWebManagementEvent(string msg,
object eventSource, int eventCode):
base(msg, eventSource, eventCode)
{
// Perform custom initialization.
eventInfo = new StringBuilder();
eventInfo.Append(string.Format(
"Event created at: ",
EventTime.ToString()));
}
// Invoked in case of events identified
// by their event code.and related
// event detailed code.
public SampleWebManagementEvent(string msg,
object eventSource, int eventCode,
int eventDetailCode):
base(msg, eventSource,
eventCode, eventDetailCode)
{
// Perform custom initialization.
eventInfo = new StringBuilder();
eventInfo.Append(string.Format(
"Event created at: ",
EventTime.ToString()));
}
// Raises the SampleWebRequestEvent.
public override void Raise()
{
// Perform custom processing.
eventInfo.Append(string.Format(
"Event raised at: ",
EventTime.ToString()));
// Raise the event.
base.Raise();
}
// Obtains the current process information.
public string GetProcessInfo()
{
StringBuilder tempPi = new StringBuilder();
WebProcessInformation pi = ProcessInformation;
tempPi.Append(
pi.ProcessName + Environment.NewLine);
tempPi.Append(
pi.ProcessID.ToString() + Environment.NewLine);
tempPi.Append(
pi.AccountName + Environment.NewLine);
return tempPi.ToString();
}
public override void FormatCustomEventDetails(
WebEventFormatter formatter)
{
base.FormatCustomEventDetails(formatter);
// Add custom data.
formatter.AppendLine("");
formatter.IndentationLevel += 1;
formatter.AppendLine(
"** SampleWebManagementEvent Start **");
// Add custom data.
formatter.AppendLine(eventInfo.ToString());
formatter.AppendLine(
"** SampleWebManagementEvent End **");
}
}
}
Imports System.Text
Imports System.Web
Imports System.Web.Management
' Implements a custom
' WebManagementEvent class.
Public Class SampleWebManagementEvent
Inherits WebManagementEvent
Private eventInfo As StringBuilder
' Invoked in case of events
' identified only by their event code.
Public Sub New(ByVal msg As String, _
ByVal eventSource As Object, _
ByVal eventCode As Integer)
MyBase.New(msg, eventSource, eventCode)
' Perform custom initialization.
eventInfo = New StringBuilder()
eventInfo.Append(String.Format( _
"Event created at: ", EventTime.ToString()))
End Sub
' Invoked in case of events identified
' by their event code.and related
' event detailed code.
Public Sub New(ByVal msg As String, _
ByVal eventSource As Object, _
ByVal eventCode As Integer, _
ByVal eventDetailCode As Integer)
MyBase.New(msg, eventSource, _
eventCode, eventDetailCode)
' Perform custom initialization.
eventInfo = New StringBuilder()
eventInfo.Append(String.Format( _
"Event created at: ", EventTime.ToString()))
End Sub
' Raises the SampleWebRequestEvent.
Public Overrides Sub Raise()
' Perform custom processing.
eventInfo.Append(String.Format( _
"Event raised at: ", EventTime.ToString()))
' Raise the event.
MyBase.Raise()
End Sub
' Obtains the current process information.
Public Function GetProcessInfo() As String
Dim tempPi As New StringBuilder()
Dim pi As WebProcessInformation = ProcessInformation
tempPi.Append( _
(pi.ProcessName + Environment.NewLine))
tempPi.Append( _
(pi.ProcessID.ToString() + Environment.NewLine))
tempPi.Append( _
(pi.AccountName + Environment.NewLine))
Return tempPi.ToString()
End Function 'GetProcessInfo
Public Overrides Sub FormatCustomEventDetails( _
ByVal formatter As WebEventFormatter)
MyBase.FormatCustomEventDetails(formatter)
' Add custom data.
formatter.AppendLine("")
formatter.IndentationLevel += 1
formatter.AppendLine( _
"** SampleWebManagementEvent Start **")
' Add custom data.
formatter.AppendLine(eventInfo.ToString())
formatter.AppendLine( _
"** SampleWebManagementEvent End **")
End Sub
End Class
下面是配置文件的摘录,使 ASP.NET 能够使用自定义事件。
<healthMonitoring enabled="true"
heartBeatInterval="0">
<eventMappings>
<add name="SampleWebManagementEvent" type="SamplesAspNet.SampleWebManagementEvent,webmanagementevent,Version=1.0.1573.24438, Culture=neutral, PublicKeyToken=2f5f337ae5c9bdaa, processorArchitecture=MSIL"/>
</eventMappings>
<rules>
<add
name="Custom WebManagementEvent"
eventName="SampleWebManagementEvent"
provider="EventLogProvider"
profile="Critical"/>
</rules>
</healthMonitoring>
注解
ASP.NET 运行状况监视允许生产和运营人员管理已部署的 Web 应用程序。 命名空间 System.Web.Management 包含负责打包应用程序运行状况状态数据的运行状况事件类型和负责处理此数据的提供程序类型。 它还包含支持类型,这些类型有助于管理运行状况事件。
WebManagementEvent 是所有 ASP.NET 运行状况监视事件类型的基类。 它使用该 WebProcessInformation 类获取其派生类可用的进程信息。
注释
在大多数情况下,你将能够使用实现的 ASP.NET 运行状况监视类型,并通过在 healthMonitoring 配置节中指定值来控制运行状况监视系统。 还可以从运行状况监视类型派生,以创建自己的自定义事件和提供程序。 有关从 WebManagementEvent 类派生的示例,请参阅本主题中提供的示例。
继承者说明
设置自定义事件信息的显示格式时,请重写 FormatCustomEventDetails(WebEventFormatter) 方法,而不是 ToString 方法。 这将避免覆盖或篡改敏感系统信息。
为自定义事件指定的事件代码必须大于 WebExtendedBase。
构造函数
| 名称 | 说明 |
|---|---|
| WebManagementEvent(String, Object, Int32, Int32) |
使用提供的参数初始化类的新实例 WebManagementEvent 。 |
| WebManagementEvent(String, Object, Int32) |
使用提供的参数初始化类的新实例 WebManagementEvent 。 |
属性
| 名称 | 说明 |
|---|---|
| EventCode |
获取与事件关联的代码值。 (继承自 WebBaseEvent) |
| EventDetailCode |
获取事件详细信息代码。 (继承自 WebBaseEvent) |
| EventID |
获取与事件关联的标识符。 (继承自 WebBaseEvent) |
| EventOccurrence |
获取一个计数器,该计数器表示事件发生的次数。 (继承自 WebBaseEvent) |
| EventSequence |
获取应用程序引发事件的次数。 (继承自 WebBaseEvent) |
| EventSource |
获取引发事件的对象。 (继承自 WebBaseEvent) |
| EventTime |
获取引发事件的时间。 (继承自 WebBaseEvent) |
| EventTimeUtc |
获取引发事件的时间。 (继承自 WebBaseEvent) |
| Message |
获取描述事件的消息。 (继承自 WebBaseEvent) |
| ProcessInformation |
获取有关 ASP.NET 应用程序托管过程的信息。 |
方法
| 名称 | 说明 |
|---|---|
| Equals(Object) |
确定指定的对象是否等于当前对象。 (继承自 Object) |
| FormatCustomEventDetails(WebEventFormatter) |
提供事件信息的标准格式。 (继承自 WebBaseEvent) |
| GetHashCode() |
用作默认哈希函数。 (继承自 Object) |
| GetType() |
获取当前实例的 Type。 (继承自 Object) |
| IncrementPerfCounters() |
在内部用于递增性能计数器。 (继承自 WebBaseEvent) |
| MemberwiseClone() |
创建当前 Object的浅表副本。 (继承自 Object) |
| Raise() |
通过通知任何配置的提供程序已发生事件来引发事件。 (继承自 WebBaseEvent) |
| ToString() |
设置用于显示目的的事件信息的格式。 (继承自 WebBaseEvent) |
| ToString(Boolean, Boolean) |
设置用于显示目的的事件信息的格式。 (继承自 WebBaseEvent) |