Bekannte EventCounter-APIs in .NET
Die .NET-Laufzeit und die .NET-Bibliotheken implementieren und veröffentlichen einige EventCounters, mit denen verschiedene Leistungsprobleme identifiziert und diagnostiziert werden können. Dieser Abschnitt bietet eine Empfehlung an Providern, die zum Überwachen dieser Counter und ihrer Beschreibungen verwendet werden können. Sehen Sie sich stattdessen die Referenz bekannter Metriken an, wenn Sie mit der neueren System.Diagnostics.Metrics-API von .NET arbeiten.
System.Runtime-Zähler
Die folgenden Leistungsindikatoren werden als Teil der .NET-Runtime (CoreCLR) veröffentlicht und im RuntimeEventSource.cs verwaltet.
Leistungsindikator | Beschreibung | Erstmals verfügbar in |
---|---|---|
% Time in GC since last GC (time-in-gc ) |
Der Prozentsatz der Zeit für GC seit der letzten GC. | .NET Core 3.1 |
Allocation Rate (alloc-rate ) |
Die Anzahl der pro Updateintervall zugeordneten Bytes | .NET Core 3.1 |
CPU Usage (cpu-usage ) |
Der Prozentsatz der CPU-Auslastung des Prozesses in Relation zu allen CPU-Ressourcen des Systems | .NET Core 3.1 |
Exception Count (exception-count ) |
Die Anzahl der aufgetretenen Ausnahmen. | .NET Core 3.1 |
GC Heap Size (gc-heap-size ) |
Die Anzahl der zugeordneten Megabytes basierend auf GC.GetTotalMemory(Boolean) | .NET Core 3.1 |
Gen 0 GC Count (gen-0-gc-count ) |
Die Anzahl der GC-Vorgänge für Gen 0 pro Updateintervall | .NET Core 3.1 |
Gen 0 Size (gen-0-size ) |
Die Anzahl der Bytes für Gen 0-GC. | .NET Core 3.1 |
Gen 1 GC Count (gen-1-gc-count ) |
Die Anzahl der GC-Vorgänge für Gen 1 pro Updateintervall | .NET Core 3.1 |
Gen 1 Size (gen-1-size ) |
Die Anzahl der Bytes für Gen 1-GC. | .NET Core 3.1 |
Gen 2 GC Count (gen-2-gc-count ) |
Die Anzahl der GC-Vorgänge für Gen 2 pro Updateintervall | .NET Core 3.1 |
Gen 2 Size (gen-2-size ) |
Die Anzahl der Bytes für Gen 2-GC. | .NET Core 3.1 |
LOH Size (loh-size ) |
Die Anzahl von Bytes für den großen Objektheap | .NET Core 3.1 |
POH Size (poh-size ) |
Die Byteanzahl für den angehefteten Objektheap (ab .NET 5 verfügbar) | .NET Core 3.1 |
GC Fragmentation (gc-fragmentation ) |
Die Fragmentierung des GC-Heap (ab .NET 5 verfügbar) | .NET Core 3.1 |
Monitor Lock Contention Count (monitor-lock-contention-count ) |
Die Anzahl der Konflikte beim Versuch, die Sperre des Monitors aufzuheben (basierend auf Monitor.LockContentionCount). | .NET Core 3.1 |
Number of Active Timers (active-timer-count ) |
Die Anzahl der derzeit aktiven Timer-Instanzen, basierend auf Timer.ActiveCount. | .NET Core 3.1 |
Number of Assemblies Loaded (assembly-count ) |
Die Anzahl der Assembly-Instanzen, die zu einem bestimmten Zeitpunkt in einen Prozess geladen wurden. | .NET Core 3.1 |
ThreadPool Completed Work Item Count (threadpool-completed-items-count ) |
Die Anzahl der Arbeitselemente, die bisher in ThreadPool verarbeitet wurden. | .NET Core 3.1 |
ThreadPool Queue Length (threadpool-queue-length ) |
Die Anzahl der Arbeitselemente, die derzeit für die Verarbeitung in ThreadPool in die Warteschlange eingereiht wurden. | .NET Core 3.1 |
ThreadPool Thread Count (threadpool-thread-count ) |
Die Anzahl der derzeit in ThreadPool vorhandenen Threads im Threadpool, basierend auf ThreadPool.ThreadCount. | .NET Core 3.1 |
Working Set (working-set ) |
Die Anzahl der Megabytes an physischem Speicher, die dem Prozesskontext zu einem bestimmten Zeitpunkt zugeordnet sind, basierend auf Environment.WorkingSet | .NET Core 3.1 |
IL Bytes Jitted (il-bytes-jitted ) |
Die Gesamtgröße der JIT-kompilierten ILs in Byte | .NET 5 |
Methods Jitted Count (methods-jitted-count ) |
Die Gesamtgröße der JIT-kompilierten Methoden | .NET 5 |
GC Committed Bytes (gc-committed ) |
Die Anzahl von Bytes, die von der GC commitet wurden | .NET 6 |
Time paused by GC (total-pause-time-by-gc ) |
Die Gesamtdauer der Programmausführung wurde von der GC angehalten. | .NET 8 |
Gen 0 GC Budget (gen-0-gc-budget ) |
Das Speicherbudget der Generation 0 | .NET 8 |
Microsoft.AspNetCore.Hosting-Leistungsindikatoren
Die folgenden Leistungsindikatoren werden als Teil von ASP.NET Core veröffentlicht und in HostingEventSource.cs verwaltet.
Leistungsindikator | Beschreibung | Erstmals verfügbar in |
---|---|---|
Current Requests (current-requests ) |
Die Gesamtanzahl von Anforderungen, die gestartet, aber noch nicht beendet wurden | .NET Core 3.1 |
Failed Requests (failed-requests ) |
Die Gesamtzahl der fehlgeschlagenen Anforderungen, die während der Lebensdauer der App aufgetreten sind. | .NET Core 3.1 |
Request Rate (requests-per-second ) |
Die Anzahl der Anforderungen pro Updateintervall | .NET Core 3.1 |
Total Requests (total-requests ) |
Die Gesamtzahl der Anforderungen, die während der Lebensdauer der App aufgetreten sind. | .NET Core 3.1 |
Microsoft.AspNetCore.Http.Verbindungs-Leistungsindikatoren
Die folgenden Leistungsindikatoren werden als Teil ASP.NET Core SignalR veröffentlicht und in HttpConnectionsEventSource.cs verwaltet.
Leistungsindikator | Beschreibung | Erstmals verfügbar in |
---|---|---|
Average Connection Duration (connections-duration ) |
Die durchschnittliche Dauer einer Verbindung in Millisekunden. | .NET Core 3.1 |
Current Connections (current-connections ) |
Die Anzahl der aktiven Verbindungen, die gestartet, aber noch nicht beendet wurden. | .NET Core 3.1 |
Total Connections Started (connections-started ) |
Die Gesamtzahl gestarteter Verbindungen. | .NET Core 3.1 |
Total Connections Stopped (connections-stopped ) |
Die Gesamtzahl von Verbindungen, die beendet wurden. | .NET Core 3.1 |
Total Connections Timed Out (connections-timed-out ) |
Die Gesamtzahl von Verbindungen, bei denen ein Timeout aufgetreten ist. | .NET Core 3.1 |
Microsoft-AspNetCore-Server-Kestrel-Leistungsindikatoren
Die folgenden Leistungsindikatoren werden als Teil des ASP.NET Core Kestrel-Webservers veröffentlicht und in KestrelEventSource.cs verwaltet.
Leistungsindikator | Beschreibung | Erstmals verfügbar in |
---|---|---|
Connection Queue Length (connection-queue-length ) |
Die aktuelle Länge der Verbindungswarteschlange. | .NET 5 |
Connection Rate (connections-per-second ) |
Die Anzahl der Verbindungen mit dem Webserver pro Updateintervall | .NET 5 |
Current Connections (current-connections ) |
Die aktuelle Anzahl aktiver Verbindungen mit dem Webserver. | .NET 5 |
Current TLS Handshakes (current-tls-handshakes ) |
Die aktuelle Anzahl von TLS-Handshakes. | .NET 5 |
Current Upgraded Requests (WebSockets) (current-upgraded-requests ) |
Aktuelle Anzahl aktualisierter Anforderungen (WebSockets) | .NET 5 |
Failed TLS Handshakes (failed-tls-handshakes ) |
Die Gesamtzahl der fehlgeschlagenen TLS-Handshakes. | .NET 5 |
Request Queue Length (request-queue-length ) |
Die aktuelle Länge der Anforderungswarteschlange. | .NET 5 |
TLS Handshake Rate (tls-handshakes-per-second ) |
Die Anzahl der TLS-Handshakes pro Updateintervall | .NET 5 |
Total Connections (total-connections ) |
Die Gesamtzahl von Verbindungen mit dem Webserver. | .NET 5 |
Total TLS Handshakes (total-tls-handshakes ) |
Die Gesamtzahl von TLS-Handshakes mit dem Webserver. | .NET 5 |
System.Net.Http-Counter
Die folgenden Leistungsindikatoren werden vom HTTP-Stapel veröffentlicht und in HttpTelemetry.AnyOS.cs verwaltet.
Leistungsindikator | Beschreibung | Erstmals verfügbar in |
---|---|---|
Requests Started (requests-started ) |
Die Anzahl der seit dem Start des Prozesses gestarteten Anforderungen | .NET 5 |
Requests Started Rate (requests-started-rate ) |
Die Anzahl der gestarteten Anforderungen pro Updateintervall | .NET 5 |
Requests Failed (requests-failed ) |
Die Anzahl von Anforderungen, bei denen seit dem Start des Prozesses Fehler aufgetreten sind | .NET 5 |
Requests Failed Rate (requests-failed-rate ) |
Die Anzahl von Anforderungen pro Updateintervall, bei denen Fehler aufgetreten sind | .NET 5 |
Current Requests (current-requests ) |
Die aktuelle Anzahl aktiver HTTP-Anforderungen, die gestartet, aber bisher noch nicht abgeschlossen oder aufgrund eines Fehlers beendet wurden | .NET 5 |
Current HTTP 1.1 Connections (http11-connections-current-total ) |
Die aktuelle Anzahl von HTTP 1.1-Verbindungen, die gestartet wurden, bisher aber noch nicht abgeschlossen sind, und bei denen bisher auch kein Fehler aufgetreten ist | .NET 5 |
Current HTTP 2.0 Connections (http20-connections-current-total ) |
Die aktuelle Anzahl von HTTP 2.0-Verbindungen, die gestartet wurden, bisher aber noch nicht abgeschlossen sind, und bei denen bisher auch kein Fehler aufgetreten ist | .NET 5 |
Current HTTP 3.0 Connections (http30-connections-current-total ) |
Die aktuelle Anzahl von HTTP 3.0-Verbindungen, die gestartet, aber bisher noch nicht abgeschlossen oder aufgrund eines Fehlers beendet wurden | .NET 7 |
HTTP 1.1 Requests Queue Duration (http11-requests-queue-duration ) |
Die durchschnittliche Zeit, die sich HTTP 1.1-Anforderungen in der Anforderungswarteschlange befinden | .NET 5 |
HTTP 2.0 Requests Queue Duration (http20-requests-queue-duration ) |
Die durchschnittliche Zeit, die sich HTTP 2.0-Anforderungen in der Anforderungswarteschlange befinden | .NET 5 |
HTTP 3.0 Requests Queue Duration (http30-requests-queue-duration ) |
Die durchschnittliche Zeit, für die sich HTTP 3.0-Anforderungen in der Anforderungswarteschlange befinden | .NET 7 |
System.Net.NameResolution-Counter
Die folgenden Leistungsindikatoren verfolgen Metriken im Zusammenhang mit DNS-Nachschlagevorgängen und werden in NameResolutionTelemetry.cs verwaltet.
Leistungsindikator | Beschreibung | Erstmals verfügbar in |
---|---|---|
DNS Lookups Requested (dns-lookups-requested ) |
Die Anzahl der seit dem Start des Prozesses angeforderten DNS-Lookups | .NET 5 |
Average DNS Lookup Duration (dns-lookups-duration ) |
Die durchschnittlich für ein DNS-Lookup benötigte Zeit | .NET 5 |
Current DNS Lookups (current-dns-lookups ) |
Die aktuelle Anzahl von DNS-Lookups, die gestartet, aber bisher noch nicht abgeschlossen oder aufgrund eines Fehlers beendet wurden | .NET 6 |
System.Net.Sicherheits-Counter
Die folgenden Leistungsindikatoren verfolgen Metriken im Zusammenhang mit dem Transport Layer Security-Protokoll und werden in NetSecurityTelemetry.cs verwaltet.
Leistungsindikator | Beschreibung | Erstmals verfügbar in |
---|---|---|
TLS handshakes completed (tls-handshake-rate ) |
Die Anzahl der abgeschlossenen TLS-Handshakes pro Updateintervall | .NET 5 |
Total TLS handshakes completed (total-tls-handshakes ) |
Die Gesamtanzahl der seit dem Start des Prozesses abgeschlossenen TLS-Handshakes | .NET 5 |
Current TLS handshakes (current-tls-handshakes ) |
Die aktuelle Anzahl von TLS-Handshakes, die gestartet wurden, bisher aber noch nicht abgeschlossen sind | .NET 5 |
Total TLS handshakes failed (failed-tls-handshakes ) |
Die Gesamtzahl von TLS-Handshakes, bei denen seit dem Start des Prozesses Fehler aufgetreten sind | .NET 5 |
All TLS Sessions Active (all-tls-sessions-open ) |
Die Anzahl aktiver TLS-Sitzungen für alle Versionen | .NET 5 |
TLS 1.0 Sessions Active (tls10-sessions-open ) |
Die Anzahl aktiver TLS 1.0-Sitzungen | .NET 5 |
TLS 1.1 Sessions Active (tls11-sessions-open ) |
Die Anzahl aktiver TLS 1.1-Sitzungen | .NET 5 |
TLS 1.2 Sessions Active (tls12-sessions-open ) |
Die Anzahl aktiver TLS 1.2-Sitzungen | .NET 5 |
TLS 1.3 Sessions Active (tls13-sessions-open ) |
Die Anzahl aktiver TLS 1.3-Sitzungen | .NET 5 |
TLS Handshake Duration (all-tls-handshake-duration ) |
Die durchschnittliche Dauer aller TLS-Handshakes | .NET 5 |
TLS 1.0 Handshake Duration (tls10-handshake-duration ) |
Die durchschnittliche Dauer von TLS 1.0-Handshakes | .NET 5 |
TLS 1.1 Handshake Duration (tls11-handshake-duration ) |
Die durchschnittliche Dauer von TLS 1.1-Handshakes | .NET 5 |
TLS 1.2 Handshake Duration (tls12-handshake-duration ) |
Die durchschnittliche Dauer von TLS 1.2-Handshakes | .NET 5 |
TLS 1.3 Handshake Duration (tls13-handshake-duration ) |
Die durchschnittliche Dauer von TLS 1.3-Handshakes | .NET 5 |
System.Net.Sockets-Counter
Die folgenden Leistungsindikatoren verfolgen Metriken im Socket Zusammenhang mit und werden in SocketsTelemetry verwaltet.
Leistungsindikator | Beschreibung | Erstmals verfügbar in |
---|---|---|
Outgoing Connections Established (outgoing-connections-established ) |
Die Gesamtanzahl ausgehender Verbindungen, die seit dem Start des Prozesses hergestellt wurden | .NET 5 |
Incoming Connections Established (incoming-connections-established ) |
Die Gesamtanzahl eingehender Verbindungen, die seit dem Start des Prozesses hergestellt wurden | .NET 5 |
Current Outgoing Connect Attempts (current-outgoing-connect-attempts ) |
Die aktuelle Anzahl ausgehender Verbindungsversuche, die gestartet, aber bisher noch nicht abgeschlossen oder aufgrund eines Fehlers beendet wurden | .NET 7 |
Bytes Received (bytes-received ) |
Die Gesamtanzahl von Bytes, die seit dem Start des Prozesses empfangen wurden | .NET 5 |
Bytes Sent (bytes-sent ) |
Die Gesamtanzahl von Bytes, die seit dem Start des Prozesses gesendet wurden | .NET 5 |
Datagrams Received (datagrams-received ) |
Die Gesamtanzahl von Datagrammen, die seit dem Start des Prozesses empfangen wurden | .NET 5 |
Datagrams Sent (datagrams-sent ) |
Die Gesamtanzahl von Datagrammen, die seit dem Start des Prozesses gesendet wurden | .NET 5 |