Teilen über


Skalieren Sie eine Web-App mithilfe benutzerdefinierter Metriken automatisch

In diesem Artikel wird schrittweise beschrieben, wie Sie die automatische Skalierung für eine Web-App mithilfe einer benutzerdefinierten Metrik im Azure-Portal einrichten.

Mit der automatischen Skalierung können Sie Ressourcen hinzufügen und entfernen, um Lastzunahmen und -abnahmen zu bewältigen. In diesem Artikel zeigen wir Ihnen, wie Sie die automatische Skalierung für eine Web-App einrichten, indem Sie eine der Application Insights-Metriken verwenden, um die Web-App zu vergrößern und zu verkleinern.

Hinweis

Die automatische Skalierung für benutzerdefinierte Metriken in Application Insights wird nur für Metriken unterstützt, die in im Namespace Standard und im Namespace Azure.ApplicationInsights veröffentlicht wurden. Wenn andere Namespaces für benutzerdefinierte Metriken in Application Insights verwendet werden, wird der Fehler Nicht unterstützte Metrik zurückgegeben.

Die automatische Skalierung von Azure Monitor gilt für:

Voraussetzungen

Sie benötigen ein Azure-Konto mit einem aktiven Abonnement. Sie können ein Konto kostenlos erstellen.

Übersicht

So erstellen Sie eine automatisch skalierte Web-App:

  1. Wenn Sie noch keinen haben, erstellen Sie einen App Service-Plan. Sie können die automatische Skalierung nicht für kostenlose oder einfache Tarife einrichten.
  2. Wenn Sie noch keine haben, erstellen Sie eine Web-App mithilfe Ihres Serviceplans.
  3. Konfigurieren Sie die automatische Skalierung für Ihren Serviceplan.

Wie erstelle ich einen Plan?

Mit einem App Service-Plan werden mehrere Computeressourcen definiert, auf denen eine Web-App ausgeführt wird.

  1. Öffnen Sie das Azure-Portal.

  2. Suchen Sie nach App Service-Plänen und wählen Sie sie aus.

    Der Screenshot zeigt die Suche nach App Service-Plänen.

  3. Wählen Sie auf der Seite App Service Plan die Option Erstellen aus.

  4. Wählen Sie eine vorhandene Ressourcengruppe aus, oder erstellen Sie eine neue.

  5. Geben Sie einen Namen für Ihren Plan ein.

  6. Wählen Sie ein Betriebssystem und eine Region aus.

  7. Wählen Sie eine SKU und Größe aus.

    Hinweis

    Sie können die automatische Skalierung nicht mit Frei- oder Basic-Tarifen verwenden.

  8. Wählen Sie Bewerten + erstellen>Erstellen aus.

    Der Screenshot, der die Registerkarte Grundlagen des Bildschirms App Service-Plan erstellen zeigt, auf dem Sie den App Service-Plan konfigurieren.

Erstellen einer Web-App

  1. Suchen Sie nach App-Diensten und wählen Sie diese aus.

    Der Screenshot zeigt die Suche nach App Services.

  2. Wählen Sie auf der Seite App Services die Option Erstellen aus.

  3. Geben Sie auf der Registerkarte Grundlagen einen Namen ein, und wählen Sie einen Runtime-Stack aus.

  4. Wählen Sie das Betriebssystem und die Region aus, die Sie beim Definieren Ihres App Service-Plans ausgewählt haben.

  5. Wählen Sie den zuvor erstellten App Service-Plan aus.

  6. Klicken Sie auf die Registerkarte Überwachung.

    Der Screenshot zeigt die Registerkarte Grundlagen der Seite Web-App erstellen, auf der Sie eine Web-App einrichten.

  7. Wählen Sie auf der Registerkarte Überwachung die Option Ja aus, um Application Insights zu aktivieren.

  8. Wählen Sie Bewerten + erstellen>Erstellen aus.

    Der Screenshot zeigt die Registerkarte Überwachung der Seite Web-App erstellen, auf der Sie Application Insights aktivieren.

Konfigurieren der automatischen Skalierung

Konfigurieren Sie die Autoskalierung-Einstellungen für Ihren App Service-Plan.

  1. Suchen und wählen Sie Autoscale in der Suchleiste oder wählen Sie Autoscale unter Überwachen in der Menüleiste auf der linken Seite aus.

  2. Wählen Sie Ihren App Service-Plan aus. Sie können nur Produktionspläne konfigurieren.

    Der Screenshot zeigt die Seite Autoscale, auf der Sie die Ressource zum Einrichten der automatischen Skalierung auswählen.

Richten Sie eine Regel für die horizontale Skalierung ein

Richten Sie eine Regel für die horizontale Skalierung ein, damit Azure eine weitere Instanz der Web-App hochfährt, wenn Ihre Web-App mehr als 70 Sitzungen pro Instanz verarbeitet.

  1. Klicken Sie auf Benutzerdefinierte Autoskalierung.

  2. Wählen Sie im Abschnitt Regeln der Standard-Skalierungsbedingung eine Regel hinzufügen aus.

    Der Screenshot zeigt die Einstellungsseite für die automatische Skalierung, auf der Sie die grundlegenden Einstellungen für die automatische Skalierung vornehmen.

  3. Wählen Sie im Drop-down-Menü Metrikquelle die Option Andere Ressource aus.

  4. Wählen Sie unter RessourcentypApplication Insights aus.

  5. Wählen Sie in der Dropdown-Liste Ressource Ihre Web-App aus.

  6. Wählen Sie einen Metrik-Namen aus, auf dem Ihre Skalierung basieren soll. Verwenden Sie beispielsweise Sitzungen.

  7. Aktivieren Sie das Kontrollkästchen Metrik-Teilung durch Instanz-Anzahl aktivieren, damit die Anzahl der Sitzungen pro Instanz gemessen wird.

  8. Wählen Sie in der Dropdown-Liste Operator die Option Größer als aus.

  9. Geben Sie den Metrik-Schwellenwert ein, um die Skalierungsaktion auszulösen. Verwenden Sie zum Beispiel 70.

  10. Stellen Sie unter Aktion die Operation auf Zähler um erhöhen. Stellen Sie die Anzahl der Instanzen auf 1 ein.

  11. Wählen Sie Hinzufügen.

    Der Screenshot zeigt die Seite Skalierungsregel, auf der Sie die Regel für horizontale Skalierung konfigurieren.

Richten Sie eine Skalierungsregel ein

Richten Sie eine Skalierungsregel ein, damit Azure eine der Instanzen herunterfährt, wenn die Anzahl der Sitzungen, die Ihre Web-App verarbeitet, weniger als 60 pro Instanz beträgt. Azure reduziert die Anzahl der Instanzen jedes Mal, wenn diese Regel ausgeführt wird, bis die Mindestanzahl von Instanzen erreicht ist.

  1. Wählen Sie im Abschnitt Regeln der Standard-Skalierungsbedingung eine Regel hinzufügen aus.

  2. Wählen Sie im Drop-down-Menü Metrikquelle die Option Andere Ressource aus.

  3. Wählen Sie unter RessourcentypApplication Insights aus.

  4. Wählen Sie in der Dropdown-Liste Ressource Ihre Web-App aus.

  5. Wählen Sie einen Metrik-Namen aus, auf dem Ihre Skalierung basieren soll. Verwenden Sie beispielsweise Sitzungen.

  6. Aktivieren Sie das Kontrollkästchen Metrik-Teilung durch Instanz-Anzahl aktivieren, damit die Anzahl der Sitzungen pro Instanz gemessen wird.

  7. Wählen Sie in der Dropdownliste Operator, wählen Sie Option Kleiner als aus.

  8. Geben Sie den Metrik-Schwellenwert ein, um die Skalierungsaktion auszulösen. Verwenden Sie zum Beispiel 60.

  9. Stellen Sie unter AktionVorgang auf Zähler verringern um und Instanzen-Zähler auf 1.

  10. Wählen Sie Hinzufügen.

    Der Screenshot zeigt die Seite Skalierungsregel, auf der Sie die Skalierungsregel konfigurieren.

Begrenzen Sie die Anzahl der Instanzen

  1. Legen Sie die maximale Anzahl von Instanzen fest, die hochgefahren werden können, im Feld Maximum des Abschnitts Instanzlimits. Verwenden Sie zum Beispiel 4.

  2. Wählen Sie Speichern aus.

    Der Screenshot zeigt die Einstellungsseite für die automatische Skalierung, auf der Sie Instanzlimits einrichten.

Bereinigen von Ressourcen

Wenn Sie diese Anwendung nicht weiter verwenden, löschen Sie Ressourcen.

  1. Wählen Sie auf der App Service-Übersichtsseite Löschen aus.

    Der Screenshot zeigt die App Service-Seite, auf der Sie die Web-App löschen können.

  2. Wählen Sie auf der Seite Einstellung für die Autoskalierung auf der Registerkarte JSON das Papierkorbsymbol neben Name der Einstellung für die Autoskalierung aus. Beachten Sie, dass die Einstellungen für die Autoskalierung nicht zusammen mit dem App Service-Plan gelöscht werden, es sei denn, Sie löschen die Ressourcengruppe. Wenn Sie die Einstellungen für die Autoskalierung nicht löschen und einen App Service-Plan mit dem gleichen Namen neu erstellen, erbt dieser die ursprünglichen Einstellungen für die Autoskalierung.

  3. Wählen Sie auf der Seite App Service-Pläne die Option Löschen aus.

    Der Screenshot zeigt die Seite mit den App Service-Plänen, auf der Sie den App Service-Plan löschen können.

Nächste Schritte

Weitere Informationen zur automatischen Skalierung finden Sie in den folgenden Artikeln: