Cronjobs mit der gcloud CLI planen und ausführen
In dieser Kurzanleitung erfahren Sie, wie Sie mit der gcloud CLI einige grundlegende Vorgänge mit Cloud Scheduler ausführen.
In dieser Kurzanleitung werden folgende Schritte erläutert:
- Erstellen Sie ein Pub/Sub-Thema, das als Ziel für den Cloud Scheduler-Job eingerichtet werden soll.
- Erstellen Sie mit Cloud Scheduler einen Cronjob und konfigurieren Sie einen wiederkehrenden Zeitplan für den Job.
- Führen Sie den Job aus.
- prüfen, ob der Job erfolgreich ausgeführt wurde
Cloud Scheduler hat eine kostenlose Stufe. Die Ausführung dieser Kurzanleitung sollte daher keine Kosten verursachen. Weitere Informationen finden Sie unter Preise.
Hinweise
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
Create or select a Google Cloud project.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_ID
with a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_ID
with your Google Cloud project name.
-
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Cloud Scheduler, Pub/Sub APIs:
gcloud services enable cloudscheduler.googleapis.com
pubsub.googleapis.com - Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
Create or select a Google Cloud project.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_ID
with a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_ID
with your Google Cloud project name.
-
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Cloud Scheduler, Pub/Sub APIs:
gcloud services enable cloudscheduler.googleapis.com
pubsub.googleapis.com
Pub/Sub-Thema und -Abo erstellen
Ein Pub/Sub-Thema ist eine Ressource, an die Publisher Nachrichten senden können. Um zu einem Thema veröffentlichte Nachrichten empfangen zu können, müssen Sie ein Abo dieses Themas erstellen.
Richten Sie ein Pub/Sub-Thema als Ziel für den Cronjob ein:
gcloud pubsub topics create cron-topic
Dadurch wird ein Thema namens
cron-topic
erstellt.Erstellen Sie ein Pub/Sub-Abo, um Nachrichten zu erhalten und die Ergebnisse des Jobs anzusehen:
gcloud pubsub subscriptions create cron-sub --topic cron-topic
Cronjob mit Cloud Scheduler erstellen
Mit dem Befehl gcloud scheduler jobs create pubsub
können Sie eine Arbeitseinheit einrichten, die als Cronjob bezeichnet wird und nach einem wiederkehrenden Zeitplan an ein Pub/Sub-Ziel gesendet wird. Der Zeitplan wird in einem Format angegeben, das auf Unix-Cron basiert. Weitere Informationen finden Sie unter Format und Zeitzone für Cronjobs.
gcloud scheduler jobs create pubsub my-cron-job \
--schedule="30 16 * * 7" \
--topic=cron-topic \
--location="us-central1" \
--message-body="Hello world"
Sie haben einen Job erstellt, der sonntags um 16:30 Uhr die Nachricht „Hallo Welt“ an Ihr Pub/Sub-Thema sendet.
Sie können den Job jetzt ausführen.
Job ausführen
Sie können einen Job nicht nur gemäß dem angegebenen Zeitplan ausführen, sondern auch sofort starten:
gcloud scheduler jobs run my-cron-job --location="us-central1"
Aufgrund der Erstkonfiguration kann es einige Minuten dauern, bis der erste Job, der in einem Projekt erstellt wurde, ausgeführt wird.
Als Nächstes können Sie prüfen, ob Ihr Pub/Sub-Thema die Nachricht erhalten hat.
Ergebnisse in Pub/Sub prüfen
Prüfen Sie, ob Ihr Pub/Sub-Thema Nachrichten von Ihrem Job empfängt.
Rufen Sie mit dem folgenden Befehl Pub/Sub-Nachrichten aus einem Abo ab:
gcloud pubsub subscriptions pull cron-sub --limit 5
Wenn keine Nachrichten abgerufen werden, führen Sie den Befehl noch einmal aus.
Sehen Sie sich die Ergebnisse des ausgeführten Jobs an. Die Ausgabe sollte ungefähr so aussehen:
DATA: Hello world! MESSAGE_ID: 5028933846601543 ORDERING_KEY: ATTRIBUTES: DELIVERY_ATTEMPT: ACK_ID: RFAGFixdRkhRNxkIaFEOT14jPzUgKEUQAgVPAihdeTFXLkFacGhRDRlyfWB9[...]
Bereinigen
Löschen Sie das Google Cloud-Projekt mit den Ressourcen, damit Ihrem Google Cloud-Konto die auf dieser Seite verwendeten Ressourcen nicht in Rechnung gestellt werden.
Delete a Google Cloud project:
gcloud projects delete PROJECT_ID
Alternativ können Sie die für diese Kurzanleitung erstellten Ressourcen löschen:
Löschen Sie den Cronjob. Führen Sie in Cloud Shell oder auf dem Computer, auf dem Sie die gcloud CLI installiert haben, den folgenden Befehl aus:
gcloud scheduler jobs delete MY_JOB \ --location="LOCATION"
Ersetzen Sie Folgendes:
MY_JOB
: Der Name des zu löschenden Jobs.LOCATION
: den Standort der Stelle. Standardmäßig wird der Speicherort der App Engine-Anwendung des aktuellen Projekts verwendet, sofern eine zugehörige App vorhanden ist.
Löschen Sie das Pub/Sub-Thema. Führen Sie in Cloud Shell oder auf dem Computer, auf dem Sie die gcloud CLI installiert haben, den folgenden Befehl aus:
gcloud pubsub topics delete TOPIC_ID
Ersetzen Sie
TOPIC_ID
durch die ID des zu löschenden Pub/Sub-Themas.Löschen Sie das Pub/Sub-Abo. Führen Sie in Cloud Shell oder auf dem Computer, auf dem Sie die gcloud CLI installiert haben, den Befehl aus:
gcloud pubsub subscriptions delete SUBSCRIPTION_ID
Ersetzen Sie
SUBSCRIPTION_ID
durch die ID des zu löschenden Pub/Sub-Abos.