Freigeben über


Fehlerbehebung bei Problemen mit hoher CPU-Leistung auf virtuellen Azure Windows-Computern

Gilt für: ✔️ Windows-VMs

Übersicht

Leistungsprobleme treten in verschiedenen Betriebssystemen oder Anwendungen auf, und für jedes Problem ist ein eigener Ansatz für die Problembehandlung erforderlich. Die meisten dieser Probleme beziehen sich auf CPU, Arbeitsspeicher, Netzwerk und Eingabe/Ausgabe (E/A) als die Schlüsselpositionen, an denen die Probleme auftreten. Jeder dieser Bereiche ruft verschiedene Symptome hervor (manchmal gleichzeitig) und erfordert eine jeweils andere Diagnose und Lösung.

In diesem Artikel werden Probleme mit hoher CPU-Auslastung erörtert, die auf virtuellen Azure-Computern (VMs) mit dem Betriebssystem Windows auftreten.

Probleme mit hoher CPU-Auslastung auf Azure-Windows-VMs

Abgesehen von den E/A- und den Netzwerklatenzproblemen erfordert die Behandlung von CPU- und Arbeitsspeicherproblemen die gleichen Tools und Schritte wie bei lokalen Servern. Eins der normalerweise von Microsoft unterstützten Tools ist PerfInsights (für Windows und Linux verfügbar). PerfInsights kann eine Diagnose in einem benutzerfreundlichen Bericht mit den bewährten Methoden für Azure-VMs bereitstellen. Perfinsight ist darüber hinaus ein Wrappertool, das beim Erfassen von Perfmon-, XPerf- und Netmon-Daten hilft, abhängig von den im Tool ausgewählten Flags.

Die meisten der vorhandenen Tools zur Problembehandlung, wie z. B. PerfMon oder Procmon, die für lokale Server verwendet werden, funktionieren auf virtuellen Azure-Computern unter Windows. PerfInsights ist jedoch explizit für Azure-VMs konzipiert, um weitere Einblicke zu bieten, einschließlich bewährter Azure-Methoden, bewährter SQL-Methoden, E/A-Latenzdiagramme mit hoher Auflösung, CPU- und Arbeitsspeicher-Registerkarten usw.

Gleich ob im Benutzermodus oder im Kernelmodus, jeder Thread eines aktiven Prozesses erfordert CPU-Zyklen, um den Code auszuführen, aus dem er besteht. Viele Probleme hängen direkt mit der Arbeitsauslastung zusammen. Die Art der Arbeitsauslastung, die auf dem Server besteht, steuert den Ressourcenverbrauch, einschließlich der CPU.

Gängige Faktoren

Die folgenden Faktoren treten in Situationen mit hoher CPU-Auslastung häufig auf:

  • Eine kürzlich erfolgte Codeänderung oder Bereitstellung, die hauptsächlich auf Apps wie IIS (Internet Information Services), Microsoft SharePoint, Microsoft SQL Server oder Anwendungen von Drittanbietern zurückzuführen ist.

  • Ein kürzlich erfolgtes Update, das möglicherweise mit einem Update auf Betriebssystemebene oder mit kumulativen Updates und Fixes auf Anwendungsebene zusammenhängt.

  • Eine geänderte Abfrage oder veraltete Indizes. Ein weiterer Faktor ist, dass SQL Server- und Oracle-Datenschichtanwendungen auch über eine Abfrageplanoptimierung verfügen. Datenänderungen oder das Fehlen geeigneter Indizes kann bewirken, dass sich die Rechenintensität mehrerer Abfragen erhöht.

  • Azure VM-spezifisch. Es gibt bestimmte Prozesse, wie etwa RDAgent, und erweiterungsspezifische Prozesse wie den Monitoring Agent, den MMA-Agent oder den Sicherheitsclient, die zu einer hohen CPU-Auslastung führen können. Diese Prozesse müssen entweder unter dem Gesichtspunkt der Konfiguration oder der bekannten Probleme betrachtet werden.

Behandeln des Problems

Dieser Artikel legt den Schwerpunkt darauf, den problematischen Prozess zu isolieren. Die weitere Analyse ist dann für den Prozess spezifisch, der die hohe CPU-Auslastung verursacht.

Wenn der Prozess beispielsweise SQL Server (sqlservr.exe) ist, bestehen die nächsten Schritte darin, zu analysieren, welche Abfrage die meisten CPU-Zyklen in einem bestimmten Zeitraum verbraucht hat.

Eingrenzen des Problemumfangs

Hier folgen einige Fragen, die Sie sich bei der Behandlung des Problems stellen können:

  • Weist das Problem ein Muster auf? Tritt das Problem der hohen CPU-Auslastung beispielsweise täglich, wöchentlich oder monatlich zu einer bestimmten Zeit auf? Wenn dies der Fall ist, können Sie das Problem mit einem Auftrag, einem Bericht oder einer Benutzeranmeldung in Beziehung setzen?

  • Ist das Problem der hohen CPU-Auslastung nach einer kürzlich erfolgten Codeänderung aufgetreten? Haben Sie ein Update in Windows oder einer Anwendung durchgeführt?

  • Hat das Problem der hohen CPU-Auslastung nach einer Änderung bei der Arbeitsauslastung, etwa einer Zunahme der Benutzeranzahl, einem größeren Datenaufkommen oder einer höheren Anzahl von Berichten begonnen?

  • Im Fall von Azure, hat das Problem mit der hohen CPU-Auslastung unter einer der folgenden Bedingungen begonnen?

    • Nach einer kürzlich erfolgten erneuten Bereitstellung oder einem Neustart
    • Nach einer Änderung der SKU oder des VM-Typs
    • Nach dem Hinzufügen einer neuen Erweiterung
    • Nachdem Änderungen am Load Balancer vorgenommen wurden

Azure-Vorbehalte

Informieren Sie sich über Ihre Arbeitsauslastung. Wenn Sie eine VM auswählen, schätzen Sie möglicherweise die Anzahl der virtuellen CPUs (vCPUs) mit dem Blick auf die monatlichen Gesamtkosten für das Hosting zu gering ein. Bei einer rechenintensiven Arbeitsauslastung kann die Wahl einer kleineren VM-SKU mit einer oder zwei vCPUs zu Problemen mit der Arbeitsauslastung führen. Testen Sie verschiedene Konfigurationen für Ihre Arbeitsauslastung, um die erforderliche Rechenkapazität zu bestimmen.

Es gibt bestimmte VM-Serien, z. B. die B-Serie (Burst Mode), die für die Verwendung in Qualitätssicherung (QS) und Tests empfohlen werden. Beim Einsatz dieser Serien in der Produktionsumgebung wird die Rechenkapazität eingeschränkt, nachdem die CPU-Guthaben erschöpft sind.

Für bekannte Anwendungen wie SQL Server, Oracle, RDS (Remote Desktop Services, Remotedesktopdienste), Windows Virtual Desktop, IIS oder SharePoint gibt es Artikel zu Best Practices für Azure mit Empfehlungen für die Minimalkonfiguration dieser Workloads.

Probleme mit fortgesetzt hoher CPU-Auslastung

Wenn das Problem aktuell auftritt, ist dies die beste Gelegenheit, die Prozessablaufverfolgung zu erfassen, um die Ursache des Problems zu bestimmen. Sie können vorhandene Tools verwenden, die Sie für lokale Windows Server eingesetzt haben, um den Prozess zu finden. Die folgenden Tools werden vom Azure-Support für Azure-VMs empfohlen.

PerfInsights

PerfInsights ist das vom Azure-Support für Leistungsprobleme bei VMs empfohlene Tool. Es wurde dafür ausgelegt, bewährte Methoden und dedizierte Analysetabs für CPU, Arbeitsspeicher und hoch aufgelöste E/A-Diagramme bereitzustellen. Sie können es bei Bedarf über das Azure-Portal oder aus der VM ausführen. Sie können die Daten mit dem Azure-Supportteam teilen.

PerfInsights ausführen

PerfInsights ist sowohl für das Windows- als auch für das Linux-Betriebssystem verfügbar. Für Windows bestehen diese Optionen.

Ausführen und Analysieren von Berichten im Azure-Portal

Bei der Installation über das Azure-Portal wird eine Erweiterung auf der VM installiert. Benutzer können PerfInsights außerdem als Erweiterung installieren, indem sie direkt zum Blatt „Erweiterungen in VM“ navigieren und dann eine Option für die Leistungsdiagnose auswählen.

Azure-Portal Option 1

Blättern Sie zum VM-Blatt, und wählen Sie die Option Leistungsdiagnose aus. Sie werden gebeten, die Option (die Erweiterungen verwendet) auf der VM zu installieren, für die Sie sie ausgewählt haben.

Screenshot der Schaltfläche „Performance Diagnostics installieren“ in der Option „Performance Diagnostics“.

Azure-Portal Option 2

Navigieren Sie zu Diagnose und Problembehandlung auf dem VM-Blatt, und suchen Sie nach VM-Leistungsprobleme.

Screenshot der VM-Leistungsprobleme in der Option „Problem diagnostizieren und lösen“.

Wenn Sie Problembehandlung auswählen, wird der Installationsbildschirm von PerfInsights geladen.

Wenn Sie Installieren auswählen, bietet die Installation verschiedene Erfassungsoptionen.

Screenshot der Einstellungen für die Leistungsanalyse in der Option „Performance Diagnostics“.

Die nummerierten Optionen im Screenshot beziehen sich auf die folgenden Kommentare:

  1. Wählen Sie für die Option Hohe CPU-Auslastung entweder Leistungsanalyse oder Erweitert aus.

  2. Wenn Sie hier Symptome hinzufügen, werden diese dem Bericht hinzugefügt, was es Ihnen leichter macht, Informationen mit dem Azure-Support zu teilen.

  3. Wählen Sie die Dauer der Datenerfassung aus. Wählen Sie für die Option „Hohe CPU-Auslastung“ mindestens 15 Minuten oder mehr aus. Im Azure-Portalmodus können Sie bis zu 15 Minuten Daten erfassen. Wenn Sie Daten über längere Zeiträume sammeln möchten, müssen Sie das Programm als ausführbare Datei innerhalb der VM ausführen.

  4. Wenn Sie vom Azure-Support aufgefordert werden, diese Daten zu sammeln, können Sie hier die Ticketnummer einfügen. Dieses Feld ist optional.

  5. Wählen Sie dieses Feld aus, um den Endbenutzer-Lizenzvertrag (EULA) zu akzeptieren.

  6. Wählen Sie dieses Feld aus, wenn Sie diesen Bericht dem Azure-Supportteam zur Verfügung stellen möchten, das Sie in diesem Fall unterstützt.

Der Bericht wird auf einem der Speicherkonten unter Ihrem Abonnement gespeichert. Er steht für Download und Anzeige zu einem späteren Zeitpunkt zur Verfügung.

Ausführen von PerfInsights in der VM

Diese Methode kann verwendet werden, wenn Sie PerfInsights für einen längeren Zeitraum ausführen möchten. Der PerfInsights-Artikel bietet eine ausführliche exemplarische Vorgehensweise zu den verschiedenen Befehlen und Flags, die zur Ausführung von PerfInsights als ausführbare Datei erforderlich sind. Für den Zweck der hohen CPU-Auslastung benötigen Sie einen der folgenden Modi:

  • Erweitertes Szenario

    • PerfInsights /run advanced xp /d 300 /AcceptDisclaimerAndShareDiagnostics
  • VM Slow-Szenario (Leistung)

    • PerfInsights /run vmslow /d 300 /AcceptDisclaimerAndShareDiagnostics /sa <StorageAccountName> /sk <StorageAccountKey>

Die Befehlsausgabe befindet sich im gleichen Ordner, in dem Sie die ausführbare PerfInsights-Datei gespeichert haben.

Wonach Sie im Bericht suchen

Nach dem Ausführen des Berichts hängt der Speicherort des Inhalts davon ab, ob die Ausführung über das Azure-Portal oder als ausführbare Datei erfolgte. Greifen Sie für beide Optionen auf den generierten Protokollordner zu, oder laden Sie ihn (im Fall des Azure-Portals) lokal für die Analyse herunter.

Ausführen über das Azure-Portal

Screenshot einer Leistungsdiagnose mit hoher Auswirkung.

Screenshot der Schaltfläche „Bericht herunterladen“ auf der Seite „Leistungsdiagnosebericht“.

Ausführen in der VM

Ihre Ordnerstruktur sollte so ähnlich wie in den folgenden Abbildungen aussehen:

Screenshot des Ausgabeordners und der HTML-Datei des PerfInsight-Berichts in Ihrer Ordnerstruktur.

Screenshot von GeneralCounters_000001.blg und System.evtx in Ihrer Ordnerstruktur.

  1. Alle weiteren Sammlungen wie etwa Perfmon, Xperf, Netmon, SMB-Protokolle, Ereignisprotokolle usw. befinden sich im Output-Ordner.

  2. Der eigentliche Bericht zusammen mit der Analyse und Empfehlungen.

  3. Sowohl für „Leistung (VMslow)“ als auch für „Erweitert“ sammelt der Bericht perfmon-Informationen für die Dauer der PerfInsights-Ausführung.

  4. Die Ereignisprotokolle zeigen eine knappe Ansicht nützlicher Absturzdetails auf Systemebene oder Prozessebene.

Erste Schritte

Öffnen Sie den PerfInsights-Bericht. Auf der Registerkarte Ergebnisse sind alle Ausreißer im Hinblick auf den Ressourcenverbrauch protokolliert. Wenn es Instanzen hoher CPU-Auslastung gibt, sind diese auf der Registerkarte Ergebnisse mit „Hohe Auswirkung“ oder „Mittlere Auswirkung“ kategorisiert.

Screenshot der Registerkarte „Ergebnisse“ in der CPU-Komponente der Seite mit dem PerfInsights-Bericht. In diesem Beispiel ist die Auswirkungsstufe „Mittel“.

Ähnlich wie im vorstehenden Beispiel wurde PerfInsights 30 Minuten lang ausgeführt. In der Hälfte dieser Zeit lastete der hervorgehobene Prozess die CPU im oberen Bereich aus. Wenn der gleiche Prozess während der gesamten Erfassungsdauer ausgeführt worden wäre, hätte sich die Auswirkungsstufe in HOCH geändert.

Wenn Sie das Ereignis Ergebnisse aufklappen, werden einige wichtige Details angezeigt. Auf der Registerkarte sind die Prozesse in absteigender Reihenfolge nach durchschnittlicher CPU-Auslastung aufgelistet und zeigen an, ob der Prozess mit dem System, einer von Microsoft stammenden App (SQL, IIS) oder einem Prozess eines Drittanbieters zusammenhängt.

Weitere Informationen

Unter CPU gibt es eine dedizierte Unterregisterkarte, die für die ausführliche Musteranalyse nach Kern oder nach Prozess verwendet werden kann.

Die Registerkarte Größte CPU-Consumer weist zwei getrennte interessierende Abschnitte auf, und hier können Sie Statistiken pro Prozessor anzeigen. Die Anwendung ist oftmals entweder als Einzelthread konzipiert oder heftet sich an einen einzelnen Prozessor an. In diesem Szenario werden ein Kern oder wenige Kerne mit 100 Prozent betrieben, während andere Kerne die erwartete Auslastung aufweisen. Diese Szenarien sind komplexer, da die durchschnittliche CPU-Auslastung auf dem Server wie erwartet zu verlaufen scheint, jedoch werden die Prozesse, die Kernen mit hoher Auslastung fest zugeordnet sind, langsamer als erwartet ausgeführt.

Screenshot der Registerkarte „Höchste CPU-Verbraucher“ im CPU-Teil der Seite mit dem PerfInsights-Bericht, wo der Analysezeitraum der Leistungsdiagnose und die Zeiträume mit hoher CPU-Nutzung angezeigt werden.

Der zweite Abschnitt (gleichermaßen wichtig) ist Größte zeitintensive CPU-Consumer. In diesem Abschnitt werden sowohl die Prozessdetails als auch das zugehörige CPU-Auslastungsmuster angezeigt. Die Liste ist nach Verbrauchern sortiert, Verbraucher mit hoher durchschnittlicher CPU-Auslastung sind oben angeordnet.

Screenshot des Abschnitts „Höchste CPU-Verbraucher mit langer Laufzeit“.

Diese beiden Registerkarten enthalten alle erforderlichen Informationen, um den Weg für die nächsten Schritte zur Problembehandlung festzulegen. Abhängig von dem Prozess, der die Situation der hohen CPU-Auslastung hervorruft, müssen Sie die Fragen angehen, die bereits zuvor formuliert wurden. Prozesse wir SQL Server (sqlservr.exe) oder IIS (w3wp.exe) erfordern einen spezifischen Drilldown zu Abfrage- oder Codeänderungen, die diese Situation verursachen. Bei Systemprozessen wie WMI oder Lsass.exe müssen Sie einen anderen Weg einschlagen.

Bei Prozessen, die mit Azure-VMs zusammenhängen, wie etwa RDAgent, OMS und Programmdateien der Überwachungserweiterungen besteht die Korrektur möglicherweise in einem neuen Build oder einer neuen Version. Nehmen Sie hierzu die Hilfe des Azure-Supportteams in Anspruch.

Perfmon (Systemmonitor)

Perfmon ist eines der ältesten Tools für die Behandlung von Ressourcenproblemen unter Windows Server. Es gibt keinen klar gegliederten Bericht mit Empfehlungen oder Ergebnissen zurück. Vielmehr muss der Benutzer die gesammelten Daten untersuchen und dazu einen spezifischen Filter unter den verschiedenen Indikatorkategorien verwenden.

PerfInsights sammelt Perfmon als zusätzliches Protokoll für VMSlow und erweiterte Szenarien. Perfmon kann jedoch unabhängig erfasst werden und bietet die folgenden zusätzlichen Vorteile:

  • Es kann remote gesammelt werden.

  • Es lässt sich mithilfe von Aufgaben planen.

  • Es kann über längere Zeiträume oder mithilfe der Roll-Over-Funktion kontinuierlich gesammelt werden.

Betrachten Sie das für PerfInsights angegebene Beispiel, um zu verstehen, wie Perfmon diese Daten darstellt. Dies sind die erforderlichen Indikatorkategorien:

  • Prozessorinformationen > %Prozessorzeit > _Gesamt

  • Prozess > %Prozessorzeit > Alle Instanzen

Erste Schritte

Die Namen der Ausgabedateien von Perfmon weisen die Erweiterung .blg auf. Sie können diese Dateien unabhängig oder mithilfe von PerfInsights sammeln. Für diese Erörterung verwenden Sie die Perfmon-.blg, die in den PerfInsights-Daten enthalten ist, die wir im vorherigen Beispiel erfasst haben.

In Perfmon gibt es keine vorbereiteten Standardberichte für den Benutzer. Es gibt verschiedene Ansichten, in denen wechselnde Diagrammtypen verwendet werden, die Filterung nach Prozessen (die Arbeit zum Identifizieren der „schuldigen“ Prozesse) erfolgt aber manuell.

Notiz

Das PAL-Tool kann .blg-Dateien verwenden und ausführliche Berichte erstellen.

Wählen Sie zunächst die Kategorie Leistungsindikatoren hinzufügen.

  1. Wählen Sie unter Verfügbare Leistungsindikatoren den Indikator % Prozessorzeit in der Kategorie Prozessorinformationen aus.

  2. Wählen Sie _Total aus, um die kombinierte Statistik für alle Kerne zu erhalten.

  3. Klicken Sie auf Hinzufügen. Das Fenster zeigt %Prozessorzeit unter Hinzugefügte Zähler.

Screenshot des Dialogfelds „Leistungsindikatoren hinzufügen“ im Systemmonitor.

Nach dem Laden der Leistungsindikatoren werden die Linien-Trenddiagramme für den Erfassungszeitraum angezeigt. Sie können die Indikatoren auswählen oder deaktivieren. Bisher haben Sie nur einen Indikator hinzugefügt.

Screenshot der Linientrenddiagramme im Erfassungszeitraum.

Jeder Indikator weist Werte für den Durchschnitt, das Minimum und das Maximum auf. Konzentrieren Sie sich auf die Werte für Durchschnitt und Maximum, da der Durchschnittswert in Abhängigkeit von der Dauer der Datenerfassung schwanken kann. Wenn die Aktivität mit der hohen CPU-Auslastung 10 Minuten lang auftrat, während die erfasste Gesamtdauer 40 Minuten betrug, sind die Durchschnittswerte viel niedriger.

Im vorstehenden Trenddiagramm ist zu ersehen, dass Total Processor (Gesamtauslastung des Prozessors) während ungefähr 15 Minuten im Bereich von fast 80 Prozent lag.

Identifizieren des Prozesses

Wir haben festgestellt, dass auf dem Server in einem bestimmten Zeitraum eine hohe CPU-Auslastung auftrat, wir haben den Auslöser aber noch nicht bestimmt. Anders als bei PerfInsights müssen Sie in diesem Fall manuell nach dem betreffenden Prozess suchen.

Für diese Aufgabe müssen Sie die zuvor hinzugefügten % Prozessorzeit-Leistungsindikatoren deaktivieren oder entfernen und dann eine neue Kategorie hinzufügen:

  • Prozess > %Prozessorzeit > Alle Instanzen

Diese Kategorie lädt Indikatoren für alle Prozesse, die zu der betreffenden Zeit ausgeführt werden.

Screenshot der Schritte zum Hinzufügen der neuen Kategorie.

Auf einem typischen Produktionscomputer können Hunderte von Prozessen ausgeführt werden. Daher kann es eine Weile dauern, alle Indikatoren mit einem niedrig verlaufenden oder flachen Trenddiagramm zu deaktivieren.

Verwenden Sie zum Beschleunigen dieses Prozesses die Histogrammansicht, und ändern Sie den Ansichtstyp von Linie in Histogramm, wodurch Sie ein Balkendiagramm erhalten. Es wird Ihnen leichter fallen, die Prozesse auszuwählen, bei denen während des Erfassungszeitraums hohe CPU-Auslastung auftritt.

Da es immer einen Balken für die Summe gibt, konzentrieren Sie sich auf die Balken, die eine hohe Auslastungsrate aufweisen. Sie können die übrigen Balken löschen, um die Ansicht aufzuräumen. Wechseln Sie nun zurück zur Linienansicht.

Screenshot der Schaltfläche „Histogrammansicht“ im Systemmonitor mit einem Beispieldiagramm, das 2 Balken enthält, die eine hohe Auslastungsrate anzeigen.

Jetzt ist es einfacher, den verantwortlichen Prozess zu bestimmen. Standardmäßig sind die Werte für Max und Min Vielfache der Anzahl entweder der Kerne auf dem Server oder der Threads des Prozesses.

Screenshot eines Linientrenddiagramms, das den verantwortlichen Prozess deutlich zeigt.

Die Liste der verfügbaren Tools endet nicht mit PerfInsights oder Perfmon. Sie haben Zugriff auf weitere Tools, wie ProcessMonitor (ProcMon) oder Xperf. Es stehen viele Tools von Drittanbietern zur Verfügung, die bei Bedarf eingesetzt werden können.

Azure-Überwachungstools

Azure-VMs bieten zuverlässige Metriken, die grundlegende Informationen wie CPU, Netzwerk-E/A und E/A-Bytes umfassen. Um erweiterte Metriken zu erhalten, wie in Azure Monitor, müssen Sie lediglich einige Optionen konfigurieren und ein Speicherkonto Ihrer Wahl verwenden.

Grundlegende Indikatoren (Standardindikatoren)

Screenshot der Seite „Metriken“ von Azure Monitor. In diesem Beispiel ist die Option „Prozentuale CPU“ in der Einstellung „Aggregation“ ausgewählt.

Aktivieren von Azure Monitor

Nachdem Sie die Azure Monitor-Metriken aktiviert haben, installiert die Software eine Erweiterung auf der VM und beginnt dann mit der Erfassung detaillierter Metriken, zu denen auch die Perfmon-Leistungsindikatoren gehören.

Screenshot des Felds „Diagnosespeicherkonto“ auf der Registerkarte „Übersicht“ der Seite „Diagnoseeinstellungen“.

Die grundlegenden Indikatorkategorien sind als Standard festgelegt. Sie können jedoch auch eine benutzerdefinierte Sammlung festlegen.

Screenshot der Option „Basiskategorien“ auf der Registerkarte „Leistungsindikatoren“ der Seite „Diagnoseeinstellungen“.

Nach dem Aktivieren der Einstellungen werden diese Gast-Indikatoren im Abschnitt Metriken angezeigt. Sie können darüber hinaus Benachrichtigungen (einschließlich E-Mail-Nachrichten) festlegen, wenn die Metriken einen bestimmten Schwellenwert erreichen.

Screenshot des Felds „Metrik-Namespace“ und der Schaltfläche „Neue Warnregel“ auf der Seite „Metriken“.

Weitere Informationen zum Verwenden von Azure Monitor zur Verwaltung von Azure-VMs finden Sie unter Überwachen von virtuellen Azure-Computern mit Azure Monitor.

Reaktive Problembehandlung

Wenn das Problem bereits aufgetreten ist, müssen Sie herausfinden, was das Problem der hohen CPU-Auslastung verursacht hat. Die reaktive Haltung kann problematisch sein. Der Modus der Datensammlung wird nicht optimal nützlich sein, da das Problem bereits aufgetreten ist.

Wenn es sich bei dem Problem um einen einmaligen Vorfall handelte, ist es möglicherweise schwierig, die App zu ermitteln, die es verursacht hat. Wenn die Azure VM für die Verwendung von OMS oder einer anderen Diagnoseüberwachung konfiguriert wurde, können Sie möglicherweise trotzdem Erkenntnisse über die Ursache des Problems erhalten.

Wenn Sie es mit einem wiederkehrenden Muster zu tun haben, erfassen Sie die Daten während des Zeitraums, in dem das Problem wahrscheinlich wieder auftritt.

PerfInsights verfügt noch nicht über eine Funktion für die Geplante Ausführung. Perfmon kann jedoch über die Befehlszeile ausgeführt und geplant werden.

Logman-Befehl

Der Logman Create Counter-Befehl wird verwendet, um die Perfmon-Sammlung über die Befehlszeile auszuführen, um sie über Task-Manager zu planen oder remote auszuführen.

Beispiel (beinhaltet den Modus zur Remoteerfassung)

Logman create counter LOGNAME -u DOMAIN\USERNAME * -f bincirc -v mmddhhmm -max 300 -c "\\SERVERNAME\LogicalDisk(*)\*" "\\SERVERNAME\Memory\*" "\\SERVERNAME\Network Interface(*)\*" "\\SERVERNAME\Paging File(*)\*" "\\SERVERNAME\PhysicalDisk(*)\*" "\\SERVERNAME\Process(*)\*" "\\SERVERNAME\Redirector\*" "\\SERVERNAME\Server\*" "\\SERVERNAME\System\*" "\\SERVERNAME\Terminal Services\*" "\\SERVERNAME\Processor(*)\*" "\\SERVERNAME\Cache\*" -si 00:01:00

„Logman.exe“ kann außerdem von einem Azure-VM-Peercomputer im gleichen VNET aus gestartet werden.

Weitere Informationen zu diesen Parametern finden Sie unter logman create counter.

Nachdem die Perfmon-Daten während des Auftretens des Problems erfasst wurden, sind die verbleibenden Schritte zum Analysieren der Daten die gleichen bereits erörterten Schritte.

Zusammenfassung

Bei jedem Leistungsproblem bildet das Verstehen Ihrer Arbeitsauslastung den Schlüssel für die Behebung. Die Optionen der verschiedenen VM-SKUs und der verschiedenen Datenträger-Speicheroptionen müssen ausgewertet werden, wobei der Schwerpunkt auf die Produktionsworkload gelegt wird. Das Testen von Lösungen auf verschiedenen VMs kann Ihnen helfen, die richtige Entscheidung zu treffen.

Da die Benutzervorgänge und das Datenvolumen Schwankungen unterliegen, halten Sie stets einen Puffer für die Berechnungs-, Netzwerk- und E/A-Funktionen der VM bereit. Dadurch haben plötzliche Änderungen der Arbeitsauslastung keine so großen Auswirkungen.

Wenn Sie absehen können, dass die Arbeitsauslastung bald zunehmen wird, steigen Sie auf eine höhere SKU mit mehr Rechenleistung um. Wählen Sie für rechenintensive Workloads die VM-SKUs mit Umsicht.

Kontaktieren Sie uns für Hilfe

Wenn Sie Fragen haben oder Hilfe mit Ihren Azure-Gutschriften benötigen, dann erstellen Sie beim Azure-Support eine Support-Anforderung oder fragen Sie den Azure Community-Support. Sie können auch Produktfeedback an die Azure Feedback Community senden.