Dobrze znane zdarzeniaCounters na platformie .NET
Środowisko uruchomieniowe i biblioteki platformy .NET implementują i publikują kilka elementów EventCounters , które mogą służyć do identyfikowania i diagnozowania różnych problemów z wydajnością. Ten artykuł zawiera informacje dotyczące dostawców, których można użyć do monitorowania tych liczników i ich opisów. Zapoznaj się z dobrze znanymi metrykami zamiast tego, jeśli pracujesz z programem . Nowszy interfejs API System.Diagnostics.Metrics platformy NET.
Liczniki System.Runtime
Poniższe liczniki są publikowane w ramach środowiska uruchomieniowego platformy .NET (CoreCLR) i są przechowywane w RuntimeEventSource.cs.
Licznik | opis | Pierwszy dostępny w programie |
---|---|---|
% Time in GC since last GC (time-in-gc ) |
Procent czasu w GC od ostatniego GC | .NET Core 3.1 |
Allocation Rate (alloc-rate ) |
Liczba bajtów przydzielonych na interwał aktualizacji | .NET Core 3.1 |
CPU Usage (cpu-usage ) |
Procent użycia procesora CPU procesu względem wszystkich zasobów procesora CPU systemu | .NET Core 3.1 |
Exception Count (exception-count ) |
Liczba wyjątków, które wystąpiły | .NET Core 3.1 |
GC Heap Size (gc-heap-size ) |
Liczba megabajtów, które należy przydzielić na podstawie GC.GetTotalMemory(Boolean) | .NET Core 3.1 |
Gen 0 GC Count (gen-0-gc-count ) |
Liczba przypadków wystąpienia GC dla 0. generacji na interwał aktualizacji | .NET Core 3.1 |
Gen 0 Size (gen-0-size ) |
Liczba bajtów dla generacji 0 GC | .NET Core 3.1 |
Gen 1 GC Count (gen-1-gc-count ) |
Liczba przypadków wystąpienia GC dla generacji 1 na interwał aktualizacji | .NET Core 3.1 |
Gen 1 Size (gen-1-size ) |
Liczba bajtów dla GC 1. generacji | .NET Core 3.1 |
Gen 2 GC Count (gen-2-gc-count ) |
Liczba przypadków wystąpienia GC dla 2. generacji na interwał aktualizacji | .NET Core 3.1 |
Gen 2 Size (gen-2-size ) |
Liczba bajtów dla gen. 2 GC | .NET Core 3.1 |
LOH Size (loh-size ) |
Liczba bajtów dla sterty dużego obiektu | .NET Core 3.1 |
POH Size (poh-size ) |
Liczba bajtów przypiętego sterty obiektu (dostępna na platformie .NET 5 i nowszych wersjach) | .NET Core 3.1 |
GC Fragmentation (gc-fragmentation ) |
Fragmentacja stert GC (dostępna na platformie .NET 5 lub nowszych wersjach) | .NET Core 3.1 |
Monitor Lock Contention Count (monitor-lock-contention-count ) |
Liczba wystąpień rywalizacji podczas próby podjęcia blokady monitora na podstawie Monitor.LockContentionCount | .NET Core 3.1 |
Number of Active Timers (active-timer-count ) |
Liczba Timer wystąpień, które są obecnie aktywne, na podstawie Timer.ActiveCount | .NET Core 3.1 |
Number of Assemblies Loaded (assembly-count ) |
Liczba Assembly wystąpień załadowanych do procesu w danym momencie | .NET Core 3.1 |
ThreadPool Completed Work Item Count (threadpool-completed-items-count ) |
Liczba elementów roboczych, które zostały przetworzone do tej pory w ThreadPool | .NET Core 3.1 |
ThreadPool Queue Length (threadpool-queue-length ) |
Liczba elementów roboczych, które są obecnie w kolejce do przetworzenia w obiekcie ThreadPool | .NET Core 3.1 |
ThreadPool Thread Count (threadpool-thread-count ) |
Liczba wątków, które obecnie istnieją w obiekcie ThreadPool, na podstawie ThreadPool.ThreadCount | .NET Core 3.1 |
Working Set (working-set ) |
Liczba megabajtów pamięci fizycznej zamapowanej na kontekst procesu w danym momencie na podstawie Environment.WorkingSet | .NET Core 3.1 |
IL Bytes Jitted (il-bytes-jitted ) |
Całkowity rozmiar list ILS skompilowanych w bajtach | .NET 5 |
Methods Jitted Count (methods-jitted-count ) |
Liczba metod skompilowanych w trybie JIT | .NET 5 |
GC Committed Bytes (gc-committed ) |
Liczba bajtów zatwierdzonych przez GC | .NET 6 |
Time paused by GC (total-pause-time-by-gc ) |
Łączna ilość czasu wykonania programu została wstrzymana przez GC | .NET 8 |
Gen 0 GC Budget (gen-0-gc-budget ) |
Budżet pamięci generacji 0 | .NET 8 |
Liczniki Microsoft.AspNetCore.Hosting
Poniższe liczniki są publikowane w ramach ASP.NET Core i są przechowywane w HostingEventSource.cs.
Licznik | opis | Pierwszy dostępny w programie |
---|---|---|
Current Requests (current-requests ) |
Łączna liczba rozpoczętych żądań, ale jeszcze nie została zatrzymana | .NET Core 3.1 |
Failed Requests (failed-requests ) |
Łączna liczba żądań zakończonych niepowodzeniem, które wystąpiły przez całe życie aplikacji | .NET Core 3.1 |
Request Rate (requests-per-second ) |
Liczba żądań występujących w interwale aktualizacji | .NET Core 3.1 |
Total Requests (total-requests ) |
Łączna liczba żądań, które wystąpiły przez całe życie aplikacji | .NET Core 3.1 |
Liczniki Microsoft.AspNetCore.Http.Connections
Poniższe liczniki są publikowane w ramach ASP.NET Core SignalR i są przechowywane w HttpConnectionsEventSource.cs.
Licznik | opis | Pierwszy dostępny w programie |
---|---|---|
Average Connection Duration (connections-duration ) |
Średni czas trwania połączenia w milisekundach | .NET Core 3.1 |
Current Connections (current-connections ) |
Liczba aktywnych połączeń, które zostały uruchomione, ale nie została jeszcze zatrzymana | .NET Core 3.1 |
Total Connections Started (connections-started ) |
Całkowita liczba rozpoczętych połączeń | .NET Core 3.1 |
Total Connections Stopped (connections-stopped ) |
Łączna liczba zatrzymanych połączeń | .NET Core 3.1 |
Total Connections Timed Out (connections-timed-out ) |
Łączna liczba połączeń, które upłynął limit czasu | .NET Core 3.1 |
Liczniki Microsoft-AspNetCore-Server-Kestrel
Poniższe liczniki są publikowane w ramach serwera internetowego ASP.NET Core Kestrel i są przechowywane w KestrelEventSource.cs.
Licznik | opis | Pierwszy dostępny w programie |
---|---|---|
Connection Queue Length (connection-queue-length ) |
Bieżąca długość kolejki połączeń | .NET 5 |
Connection Rate (connections-per-second ) |
Liczba połączeń na interwał aktualizacji serwera internetowego | .NET 5 |
Current Connections (current-connections ) |
Bieżąca liczba aktywnych połączeń z serwerem sieci Web | .NET 5 |
Current TLS Handshakes (current-tls-handshakes ) |
Bieżąca liczba uzgadniań protokołu TLS | .NET 5 |
Current Upgraded Requests (WebSockets) (current-upgraded-requests ) |
Bieżąca liczba uaktualnionych żądań (WebSocket) | .NET 5 |
Failed TLS Handshakes (failed-tls-handshakes ) |
Całkowita liczba nieudanych uzgadniań protokołu TLS | .NET 5 |
Request Queue Length (request-queue-length ) |
Bieżąca długość kolejki żądań | .NET 5 |
TLS Handshake Rate (tls-handshakes-per-second ) |
Liczba uzgadniań protokołu TLS na interwał aktualizacji | .NET 5 |
Total Connections (total-connections ) |
Całkowita liczba połączeń z serwerem sieci Web | .NET 5 |
Total TLS Handshakes (total-tls-handshakes ) |
Całkowita liczba uzgadniań protokołu TLS z serwerem internetowym | .NET 5 |
Liczniki System.Net.Http
Następujące liczniki są publikowane przez stos HTTP i są przechowywane w HttpTelemetry.AnyOS.cs.
Licznik | opis | Pierwszy dostępny w programie |
---|---|---|
Requests Started (requests-started ) |
Liczba żądań rozpoczętych od rozpoczęcia procesu | .NET 5 |
Requests Started Rate (requests-started-rate ) |
Liczba żądań rozpoczętych na interwał aktualizacji | .NET 5 |
Requests Failed (requests-failed ) |
Liczba żądań zakończonych niepowodzeniem od rozpoczęcia procesu | .NET 5 |
Requests Failed Rate (requests-failed-rate ) |
Liczba żądań zakończonych niepowodzeniem na interwał aktualizacji | .NET 5 |
Current Requests (current-requests ) |
Bieżąca liczba aktywnych żądań HTTP, które zostały uruchomione, ale nie zostały jeszcze ukończone lub zakończone niepowodzeniem | .NET 5 |
Current HTTP 1.1 Connections (http11-connections-current-total ) |
Bieżąca liczba połączeń HTTP 1.1, które zostały uruchomione, ale nie zostały jeszcze zakończone lub nie powiodły się | .NET 5 |
Current HTTP 2.0 Connections (http20-connections-current-total ) |
Bieżąca liczba połączeń HTTP 2.0, które zostały uruchomione, ale nie zostały jeszcze zakończone lub nie powiodły się | .NET 5 |
Current HTTP 3.0 Connections (http30-connections-current-total ) |
Bieżąca liczba połączeń HTTP 3.0, które zostały uruchomione, ale nie zostały jeszcze zakończone lub nie powiodły się | .NET 7 |
HTTP 1.1 Requests Queue Duration (http11-requests-queue-duration ) |
Średni czas trwania żądań HTTP 1.1 spędzonych w kolejce żądań | .NET 5 |
HTTP 2.0 Requests Queue Duration (http20-requests-queue-duration ) |
Średni czas trwania żądań HTTP 2.0 spędzonych w kolejce żądań | .NET 5 |
HTTP 3.0 Requests Queue Duration (http30-requests-queue-duration ) |
Średni czas trwania żądań HTTP 3.0 spędzonych w kolejce żądań | .NET 7 |
Liczniki System.Net.NameResolution
Poniższe liczniki śledzą metryki związane z wyszukiwaniami DNS i są przechowywane w NameResolutionTelemetry.cs.
Licznik | opis | Pierwszy dostępny w programie |
---|---|---|
DNS Lookups Requested (dns-lookups-requested ) |
Liczba żądań wyszukiwania DNS od rozpoczęcia procesu | .NET 5 |
Average DNS Lookup Duration (dns-lookups-duration ) |
Średni czas potrzebny na wyszukiwanie DNS | .NET 5 |
Current DNS Lookups (current-dns-lookups ) |
Bieżąca liczba wyszukiwań DNS, które zostały uruchomione, ale nie zostały jeszcze ukończone lub zakończone niepowodzeniem | .NET 6 |
Liczniki System.Net.Security
Poniższe liczniki śledzą metryki związane z protokołem Transport Layer Security i są przechowywane w NetSecurityTelemetry.cs.
Licznik | opis | Pierwszy dostępny w programie |
---|---|---|
TLS handshakes completed (tls-handshake-rate ) |
Liczba ukończonych uzgadniań protokołu TLS w interwale aktualizacji | .NET 5 |
Total TLS handshakes completed (total-tls-handshakes ) |
Całkowita liczba ukończonych uzgadniań protokołu TLS od czasu rozpoczęcia procesu | .NET 5 |
Current TLS handshakes (current-tls-handshakes ) |
Bieżąca liczba uzgadniań protokołu TLS, które zostały uruchomione, ale nie zostały jeszcze ukończone | .NET 5 |
Total TLS handshakes failed (failed-tls-handshakes ) |
Całkowita liczba zakończonych niepowodzeniem uzgadniania protokołu TLS od rozpoczęcia procesu | .NET 5 |
All TLS Sessions Active (all-tls-sessions-open ) |
Liczba aktywnych sesji protokołu TLS dowolnej wersji | .NET 5 |
TLS 1.0 Sessions Active (tls10-sessions-open ) |
Liczba aktywnych sesji protokołu TLS 1.0 | .NET 5 |
TLS 1.1 Sessions Active (tls11-sessions-open ) |
Liczba aktywnych sesji protokołu TLS 1.1 | .NET 5 |
TLS 1.2 Sessions Active (tls12-sessions-open ) |
Liczba aktywnych sesji protokołu TLS 1.2 | .NET 5 |
TLS 1.3 Sessions Active (tls13-sessions-open ) |
Liczba aktywnych sesji protokołu TLS 1.3 | .NET 5 |
TLS Handshake Duration (all-tls-handshake-duration ) |
Średni czas trwania wszystkich uzgadniań protokołu TLS | .NET 5 |
TLS 1.0 Handshake Duration (tls10-handshake-duration ) |
Średni czas trwania uzgadniania protokołu TLS 1.0 | .NET 5 |
TLS 1.1 Handshake Duration (tls11-handshake-duration ) |
Średni czas trwania uzgadniania protokołu TLS 1.1 | .NET 5 |
TLS 1.2 Handshake Duration (tls12-handshake-duration ) |
Średni czas trwania uzgadniania protokołu TLS 1.2 | .NET 5 |
TLS 1.3 Handshake Duration (tls13-handshake-duration ) |
Średni czas trwania uzgadniania protokołu TLS 1.3 | .NET 5 |
Liczniki System.Net.Sockets
Poniższe liczniki śledzą metryki związane z Socket elementami i są obsługiwane w elememetrii SocketsTelemetry.
Licznik | opis | Pierwszy dostępny w programie |
---|---|---|
Outgoing Connections Established (outgoing-connections-established ) |
Całkowita liczba połączeń wychodzących ustanowionych od czasu rozpoczęcia procesu | .NET 5 |
Incoming Connections Established (incoming-connections-established ) |
Łączna liczba nawiązanych połączeń przychodzących od rozpoczęcia procesu | .NET 5 |
Current Outgoing Connect Attempts (current-outgoing-connect-attempts ) |
Bieżąca liczba prób nawiązania połączenia wychodzącego, które zostały uruchomione, ale nie zostały jeszcze zakończone lub zakończyły się niepowodzeniem | .NET 7 |
Bytes Received (bytes-received ) |
Całkowita liczba bajtów odebranych od rozpoczęcia procesu | .NET 5 |
Bytes Sent (bytes-sent ) |
Całkowita liczba bajtów wysłanych od momentu rozpoczęcia procesu | .NET 5 |
Datagrams Received (datagrams-received ) |
Całkowita liczba odebranych datagramów od rozpoczęcia procesu | .NET 5 |
Datagrams Sent (datagrams-sent ) |
Łączna liczba wysłanych datagramów od rozpoczęcia procesu | .NET 5 |