Sie können eine Monitoring-Benachrichtigung erstellen, um informiert zu werden, wenn ein Dataproc-Cluster oder Jobmesswert einen bestimmten Grenzwert überschreitet.
Schritte zum Erstellen einer Benachrichtigung
So erstellen Sie eine Benachrichtigung:
Öffnen Sie den Bereich Benachrichtigungen. in der Google Cloud Console.
Klicken Sie auf + Richtlinie erstellen, um die Seite Benachrichtigungsrichtlinie erstellen zu öffnen.
- Klicken Sie auf Messwert auswählen.
- Wählen Sie im Bereich „Nach Ressourcen- oder Messwertname filtern“ Eingabefeld Geben Sie „Dataproc“ ein um Dataproc-Messwerte aufzulisten. Navigieren Sie durch die Hierarchie der Cloud Dataproc-Messwerte, um einen Cluster, Job, Batch oder Sitzungsmesswerts.
- Klicken Sie auf Anwenden.
- Klicken Sie auf Weiter, um den Bereich Trigger für Benachrichtigungen konfigurieren zu öffnen.
- Legen Sie einen Grenzwert fest, um die Benachrichtigung auszulösen.
- Klicken Sie auf Weiter, um das Fenster Benachrichtigungen konfigurieren und Benachrichtigung fertigstellen zu öffnen. .
- Legen Sie Benachrichtigungskanäle, Dokumentation und den Namen der Benachrichtigungsrichtlinie fest.
- Klicken Sie auf Weiter, um die Benachrichtigungsrichtlinie aufzurufen.
- Klicken Sie auf Richtlinie erstellen, um die Benachrichtigung zu erstellen.
Beispielbenachrichtigungen
In diesem Abschnitt wird eine Beispielbenachrichtigung für einen Job beschrieben, der an den Dataproc-Dienst gesendet wurde, und eine Benachrichtigung für einen Job, der als YARN-Anwendung ausgeführt wird.
Benachrichtigung über einen lange laufenden Dataproc-Job
Dataproc gibt den Messwert dataproc.googleapis.com/job/state
aus, mit dem erfasst wird, wie lange sich ein Job in verschiedenen Status befunden hat. Dieser Messwert ist im Metrics Explorer der Google Cloud Console unter der Ressource Cloud Dataproc-Job (cloud_dataproc_job) zu finden.
Mit diesem Messwert können Sie eine Benachrichtigung einrichten, die Sie informiert, wenn der Job
Der Status „RUNNING
“ überschreitet einen Grenzwert für die Dauer.
Benachrichtigung für die Jobdauer einrichten
In diesem Beispiel wird Monitoring Query Language (MQL) verwendet, um Erstellen Sie eine Benachrichtigungsrichtlinie (siehe MQL-Benachrichtigungsrichtlinien erstellen) (Console).
fetch cloud_dataproc_job
| metric 'dataproc.googleapis.com/job/state'
| filter metric.state == 'RUNNING'
| group_by [resource.job_id, metric.state], 1m
| condition val() == true()
Im folgenden Beispiel wird die Benachrichtigung ausgelöst, wenn ein Job ausgeführt wird länger als 30 Minuten.
Sie können die Abfrage ändern, indem Sie nach resource.job_id
filtern, um sie auf einen bestimmten Job anzuwenden:
fetch cloud_dataproc_job
| metric 'dataproc.googleapis.com/job/state'
| filter (resource.job_id == '1234567890') && (metric.state == 'RUNNING')
| group_by [resource.job_id, metric.state], 1m
| condition val() == true()
Benachrichtigung über eine lange laufende YARN-Anwendung
Im vorherigen Beispiel wird eine Benachrichtigung ausgelöst, wenn ein Dataproc-Job länger als eine bestimmte Dauer ausgeführt wird. Sie gilt jedoch nur für Jobs, die über die Google Cloud Console, die Google Cloud CLI oder durch direkte Aufrufe der Dataproc jobs
API an den Dataproc-Dienst gesendet werden. Sie können auch OSS-Messwerte verwenden,
, um ähnliche Benachrichtigungen einzurichten, die die Laufzeit von YARN-Anwendungen überwachen.
Zunächst ein paar Hintergrundinformationen. YARN gibt Laufzeitmesswerte in mehreren Buckets aus.
Standardmäßig verwendet YARN die Bucket-Grenzwerte 60, 300 und 1440 Minuten und gibt vier Messwerte aus: running_0
, running_60
, running_300
und running_1440
:
running_0
zeichnet die Anzahl der Jobs mit einer Laufzeit zwischen 0 und 60 Minuten auf.running_60
zeichnet die Anzahl der Jobs mit einer Laufzeit zwischen 60 und 300 Minuten auf.running_300
zeichnet die Anzahl der Jobs mit einer Laufzeit zwischen 300 und 1.440 Minuten auf.running_1440
gibt die Anzahl der Jobs mit einer Laufzeit von mehr als 1.440 Minuten an.
Ein Job, der beispielsweise 72 Minuten lang ausgeführt wird, wird in running_60
, aber nicht in running_0
aufgezeichnet.
Diese Standard-Bucket-Grenzwerte können geändert werden, indem Sie beim Erstellen eines Dataproc-Clusters neue Werte an das yarn:yarn.resourcemanager.metrics.runtime.buckets
Cluster-Attribut übergeben. Wenn Sie Grenzwerte für benutzerdefinierte Bucket-Kategorien festlegen, müssen Sie auch Messwertüberschreibungen definieren. Wenn Sie beispielsweise Bucket-Grenzwerte von 30, 60 und 90 Minuten angeben möchten, sollte der gcloud dataproc clusters create
-Befehl die folgenden Flags enthalten:
Bucket-Grenzwerte:
‑‑properties=yarn:yarn.resourcemanager.metrics.runtime.buckets=30,60,90
Messwertüberschreibungen:
‑‑metric-overrides=yarn:ResourceManager:QueueMetrics:running_0, yarn:ResourceManager:QueueMetrics:running_30,yarn:ResourceManager:QueueMetrics:running_60, yarn:ResourceManager:QueueMetrics:running_90
Beispielbefehl zur Clustererstellung
gcloud dataproc clusters create test-cluster \ --properties ^#^yarn:yarn.resourcemanager.metrics.runtime.buckets=30,60,90 \ --metric-sources=yarn \ --metric-overrides=yarn:ResourceManager:QueueMetrics:running_0,yarn:ResourceManager:QueueMetrics:running_30,yarn:ResourceManager:QueueMetrics:running_60,yarn:ResourceManager:QueueMetrics:running_90
Diese Messwerte werden im Metrics Explorer der Google Cloud Console aufgelistet in der Ressource VM-Instanz (gce_instance)
Benachrichtigungen für die YARN-Anwendung einrichten
Erstellen Sie einen Cluster mit aktivierten erforderlichen Buckets und Messwerten.
Erstellen Sie eine Benachrichtigungsrichtlinie, die ausgelöst wird, wenn die Anzahl der Anwendungen in einem YARN-Messwert-Bucket einen bestimmten Schwellenwert überschreiten.
Fügen Sie optional einen Filter hinzu, um Benachrichtigungen zu Clustern zu erhalten, die einem Muster entsprechen.
Konfigurieren Sie den Grenzwert zum Auslösen der Benachrichtigung.
Benachrichtigung zu einem fehlgeschlagenen Dataproc-Job
Sie können auch den Messwert dataproc.googleapis.com/job/state
verwenden
(siehe Dataproc-Jobbenachrichtigung mit langer Ausführungszeit)
um Sie zu benachrichtigen, wenn ein Dataproc-Job fehlschlägt.
Einrichtung von Stellenbenachrichtigungen fehlgeschlagen
In diesem Beispiel wird Monitoring Query Language (MQL) verwendet, um Erstellen Sie eine Benachrichtigungsrichtlinie (siehe MQL-Benachrichtigungsrichtlinien erstellen) (Console).
Benachrichtigungs-MQL
fetch cloud_dataproc_job
| metric 'dataproc.googleapis.com/job/state'
| filter metric.state == 'ERROR'
| group_by [resource.job_id, metric.state], 1m
| condition val() == true()
Konfiguration des Triggers für Benachrichtigungen
Im folgenden Beispiel wird die Benachrichtigung ausgelöst, wenn Dataproc Job in Ihrem Projekt fehlschlägt.
Sie können die Abfrage ändern, indem Sie nach resource.job_id
filtern, um sie auf einen bestimmten Job anzuwenden:
fetch cloud_dataproc_job
| metric 'dataproc.googleapis.com/job/state'
| filter (resource.job_id == '1234567890') && (metric.state == 'ERROR')
| group_by [resource.job_id, metric.state], 1m
| condition val() == true()
Benachrichtigung zur Clusterkapazitätsabweichung
Dataproc gibt den Messwert dataproc.googleapis.com/cluster/capacity_deviation
aus, der die Differenz zwischen der erwarteten Knotenanzahl im Cluster und der Anzahl der aktiven YARN-Knoten angibt. Sie finden diesen Messwert im Metrics Explorer der Google Cloud Console unter der Ressource Cloud Dataproc-Cluster. Sie können diesen Messwert verwenden, um eine Benachrichtigung zu erstellen, die Sie informiert, wenn die Clusterkapazität länger als eine bestimmte Schwellendauer von der erwarteten Kapazität abweicht.
Die folgenden Vorgänge können zu einer vorübergehenden Unterberichterstattung von Clusterknoten führen
im Messwert capacity_deviation
. Um Fehlalarme zu vermeiden, legen Sie den Grenzwert für Messwertbenachrichtigungen so fest, dass diese Vorgänge berücksichtigt werden:
Clustererstellung und -aktualisierungen: Der Messwert
capacity_deviation
ist nicht die bei Cluster-Erstellungs- oder -Aktualisierungsvorgängen ausgegeben werden.Cluster-Initialisierungsaktionen: Initialisierungsaktionen werden ausgeführt. nachdem ein Knoten bereitgestellt wurde.
Updates für sekundäre Worker: Sekundäre Worker werden asynchron hinzugefügt, nach Abschluss des Aktualisierungsvorgangs.
Einrichtung der Benachrichtigung zur Kapazitätsabweichung
In diesem Beispiel wird Monitoring Query Language (MQL) verwendet, um Erstellen Sie eine Benachrichtigungsrichtlinie.
fetch cloud_dataproc_cluster
| metric 'dataproc.googleapis.com/cluster/capacity_deviation'
| every 1m
| condition val() <> 0 '1'
Im nächsten Beispiel wird die Benachrichtigung ausgelöst, wenn die Abweichung der Clusterkapazität länger als 30 Minuten nicht null ist.
Benachrichtigungen ansehen
Wenn eine Benachrichtigung durch eine Messwertschwellenbedingung ausgelöst wird, erstellt Monitoring einen Vorfall sowie ein entsprechendes Ereignis. Sie können Vorfälle auf der Seite Monitoring-Benachrichtigungen in der Google Cloud Console aufrufen.
Wenn Sie in der Benachrichtigungsrichtlinie einen Benachrichtigungsmechanismus wie E-Mail- oder SMS-Benachrichtigungen festgelegt haben, Monitoring sendet eine Benachrichtigung über den Vorfall.
Weitere Informationen
- Weitere Informationen finden Sie unter Einführung in Benachrichtigungen.