Endpunkt "Zeitpläne"
Zeitpläne sind ein Tool, mit dem Batch-Segmentierungsaufträge einmal täglich automatisch ausgeführt werden können. Sie können den Endpunkt /config/schedules
verwenden, um eine Liste von Zeitplänen abzurufen, einen neuen Zeitplan zu erstellen, Details eines bestimmten Zeitplans abzurufen, einen bestimmten Zeitplan zu aktualisieren oder einen bestimmten Zeitplan zu löschen.
Erste Schritte
Die in diesem Handbuch verwendeten Endpunkte sind Teil der Adobe Experience Platform Segmentation Service -API. Bevor Sie fortfahren, lesen Sie zunächst das Erste-Schritte-Handbuch , um wichtige Informationen zu erhalten, die Sie benötigen, um die API erfolgreich aufrufen zu können, einschließlich erforderlicher Kopfzeilen und Anweisungen zum Lesen von Beispiel-API-Aufrufen.
Abrufen einer Liste von Zeitplänen retrieve-list
Sie können eine Liste aller Zeitpläne für Ihr Unternehmen abrufen, indem Sie eine GET-Anfrage an den Endpunkt /config/schedules
senden.
API-Format
Der /config/schedules
-Endpunkt unterstützt verschiedene Abfrageparameter, mit denen Sie Ihre Ergebnisse filtern können. Diese Parameter sind zwar optional, doch wird ihre Verwendung dringend empfohlen, um den teuren Verwaltungsaufwand zu reduzieren. Wenn Sie diesen Endpunkt ohne Parameter aufrufen, werden alle für Ihre Organisation verfügbaren Zeitpläne abgerufen. Es können mehrere Parameter eingeschlossen werden, die durch kaufmännische Und-Zeichen (&
) voneinander getrennt werden.
GET /config/schedules
GET /config/schedules?{QUERY_PARAMETERS}
Abfrageparameter
table 0-row-3 1-row-3 2-row-3 | ||
---|---|---|
Parameter | Beschreibung | Beispiel |
start |
Gibt an, von welcher Seite der Offset beginnt. Der Standardwert ist 0. | start=5 |
limit |
Gibt die Anzahl der Zeitpläne an, die zurückgegeben werden. Der Standardwert ist 100. | limit=20 |
Anfrage
Mit der folgenden Anfrage werden die letzten zehn Zeitpläne abgerufen, die innerhalb Ihres Unternehmens veröffentlicht wurden.
code language-shell |
---|
|
Antwort
Eine erfolgreiche Antwort gibt den HTTP-Status 200 mit einer Liste von Zeitplänen für die angegebene Organisation als JSON zurück.
code language-json |
---|
|
table 0-row-2 1-row-2 2-row-2 3-row-2 4-row-2 5-row-2 6-row-2 7-row-2 8-row-2 | |
---|---|
Eigenschaft | Beschreibung |
_page.totalCount |
Die Gesamtzahl der zurückgegebenen Zeitpläne. |
_page.pageSize |
Die Größe der Seite der Zeitpläne. |
children.name |
Der Name des Zeitplans als Zeichenfolge. |
children.type |
Der Auftragstyp als Zeichenfolge. Die beiden unterstützten Typen sind "batch_segmentation"und "export". |
children.properties |
Ein Objekt, das zusätzliche Eigenschaften im Zusammenhang mit dem Zeitplan enthält. |
children.properties.segments |
Durch Verwendung von ["*"] wird sichergestellt, dass alle Segmente einbezogen werden. |
children.schedule |
Eine Zeichenfolge, die den Auftragsplan enthält. Aufträge können nur einmal pro Tag ausgeführt werden. Das bedeutet, dass Sie nicht planen können, dass ein Auftrag innerhalb eines Zeitraums von 24 Stunden mehrmals ausgeführt wird. Weitere Informationen zu Cron-Zeitplänen finden Sie im Anhang zum Cron-Ausdrucksformat. In diesem Beispiel bedeutet "0 0 1 * *", dass dieser Zeitplan täglich um 1 Uhr ausgeführt wird. |
children.state |
Eine Zeichenfolge, die den Status des Zeitplans enthält. Die beiden unterstützten Status sind "aktiv"und "inaktiv". Standardmäßig ist der Status auf "inaktiv"festgelegt. |
Erstellen neuer Zeitpläne create
Sie können einen neuen Zeitplan erstellen, indem Sie eine POST-Anfrage an den Endpunkt /config/schedules
senden.
API-Format
POST /config/schedules
Anfrage
code language-shell |
---|
|
table 0-row-2 1-row-2 2-row-2 3-row-2 4-row-2 5-row-2 6-row-2 | |
---|---|
Eigenschaft | Beschreibung |
name |
Erforderlich. Der Name des Zeitplans als Zeichenfolge. |
type |
Erforderlich. Der Auftragstyp als Zeichenfolge. Die beiden unterstützten Typen sind "batch_segmentation"und "export". |
properties |
Erforderlich. Ein Objekt, das zusätzliche dem Zeitplan zugehörige Eigenschaften enthält. |
properties.segments |
Erforderlich, wenn type gleich "batch_segmentation"ist. Mit ["*"] wird sichergestellt, dass alle Segmente einbezogen werden. |
schedule |
Optional. Eine Zeichenfolge, die den Zeitplan für den Auftrag enthält. Aufträge können nur einmal pro Tag ausgeführt werden. Das bedeutet, dass Sie nicht planen können, dass ein Auftrag innerhalb eines Zeitraums von 24 Stunden mehrmals ausgeführt wird. Weitere Informationen zu Cron-Zeitplänen finden Sie im Anhang zum Cron-Ausdrucksformat. In diesem Beispiel bedeutet "0 0 1 * *", dass dieser Zeitplan täglich um 1 Uhr ausgeführt wird. Wenn diese Zeichenfolge nicht angegeben wird, wird automatisch ein vom System generierter Zeitplan generiert. |
state |
Optional. Eine Zeichenfolge, die den Status des Zeitplans enthält. Die beiden unterstützten Status sind "aktiv"und "inaktiv". Standardmäßig ist der Status auf "inaktiv"festgelegt. |
Antwort
Eine erfolgreiche Antwort gibt den HTTP-Status-Code 200 mit Details zum von Ihnen neu erstellten Zeitplan zurück.
code language-json |
---|
|
Abrufen einzelner Zeitpläne get
Sie können detaillierte Informationen zu einem bestimmten Zeitplan abrufen, indem Sie eine GET-Anfrage an den /config/schedules
-Endpunkt senden und im Anfragepfad die Kennung des Zeitplans angeben, den Sie abrufen möchten.
API-Format
GET /config/schedules/{SCHEDULE_ID}
{SCHEDULE_ID}
id
-Wert des Zeitplans, den Sie abrufen möchten.Anfrage
code language-shell |
---|
|
Antwort
Eine erfolgreiche Antwort gibt den HTTP-Status-Code 200 mit Details zum angegebenen Zeitplan zurück.
code language-json |
---|
|
table 0-row-2 1-row-2 2-row-2 3-row-2 4-row-2 5-row-2 6-row-2 | |
---|---|
Eigenschaft | Beschreibung |
name |
Der Name des Zeitplans als Zeichenfolge. |
type |
Der Auftragstyp als Zeichenfolge. Unterstützt werden die Typen batch_segmentation und export . |
properties |
Ein Objekt, das zusätzliche Eigenschaften im Zusammenhang mit dem Zeitplan enthält. |
properties.segments |
Durch Verwendung von ["*"] wird sichergestellt, dass alle Segmente einbezogen werden. |
schedule |
Eine Zeichenfolge, die den Auftragsplan enthält. Aufträge können nur einmal pro Tag ausgeführt werden, d. h., Sie können einen Auftrag nicht so planen, dass er während eines Zeitraums von 24 Stunden mehr als einmal ausgeführt wird. Weitere Informationen zu Cron-Zeitplänen finden Sie im Anhang zum Cron-Ausdrucksformat. In diesem Beispiel bedeutet "0 0 1 * *", dass dieser Zeitplan täglich um 1 Uhr ausgeführt wird. |
state |
Eine Zeichenfolge, die den Status des Zeitplans enthält. Unterstützt werden die Status active und inactive . Standardmäßig lautet der Status inactive . |
Aktualisieren von Details für einen bestimmten Zeitplan update
Sie können einen bestimmten Zeitplan aktualisieren, indem Sie eine PATCH-Anfrage an den /config/schedules
-Endpunkt senden und im Anfragepfad die Kennung des Zeitplans angeben, den Sie aktualisieren möchten.
Mit der PATCH-Anfrage können Sie entweder den Status oder den Cron-Zeitplan für einen einzelnen Zeitplan aktualisieren.
API-Format
PATCH /config/schedules/{SCHEDULE_ID}
{SCHEDULE_ID}
id
-Wert des Zeitplans, den Sie aktualisieren möchten.Sie können einen JSON Patch-Vorgang verwenden, um den Status des Zeitplans zu aktualisieren. Um den Status zu aktualisieren, deklarieren Sie die path
-Eigenschaft als /state
und setzen die value
auf entweder active
oder inactive
. Weitere Informationen zum JSON Patch finden Sie in der Dokumentation zum JSON Patch .
Anfrage
accordion | ||
---|---|---|
Eine Beispielanfrage zum Aktualisieren des Zeitplanstatus. | ||
|
table 0-row-2 1-row-2 2-row-2 | |
---|---|
Eigenschaft | Beschreibung |
path |
Der Pfad des Werts, den Sie ändern möchten. Da Sie in diesem Fall den Status des Zeitplans aktualisieren, müssen Sie den Wert von path auf "/state"setzen. |
value |
Der aktualisierte Wert des Status des Zeitplans. Dieser Wert kann entweder als "aktiv"oder "inaktiv"festgelegt werden, um den Zeitplan zu aktivieren oder zu deaktivieren. Beachten Sie, dass Sie einen Zeitplan nicht deaktivieren können, wenn die Organisation für Streaming aktiviert wurde. |
Antwort
Bei erfolgreicher Antwort wird der HTTP-Status-Code 204 (kein Inhalt) zurückgegeben.
path
-Eigenschaft als /schedule
und setzen die value
auf einen gültigen Cron-Zeitplan. Weitere Informationen zum JSON Patch finden Sie in der Dokumentation zum JSON Patch . Weitere Informationen zu Cron-Zeitplänen finden Sie im Anhang zum Cron-Ausdrucksformat.Anfrage
code language-shell |
---|
|
table 0-row-2 1-row-2 2-row-2 | |
---|---|
Eigenschaft | Beschreibung |
path |
Der Pfad des Werts, den Sie aktualisieren möchten. Da Sie in diesem Fall den Cron-Zeitplan aktualisieren, müssen Sie den Wert von path auf /schedule setzen. |
value |
Der aktualisierte Wert des Cron-Zeitplans. Dieser Wert muss in Form eines Cron-Zeitplans angegeben werden. In diesem Beispiel wird der Zeitplan am zweiten Tag jedes Monats ausgeführt. |
Antwort
Bei erfolgreicher Antwort wird der HTTP-Status-Code 204 (kein Inhalt) zurückgegeben.
Löschen einzelner Zeitpläne
Sie können das Löschen eines bestimmten Zeitplans anfordern, indem Sie eine DELETE-Anfrage an den /config/schedules
-Endpunkt senden und im Anfragepfad die Kennung des Zeitplans angeben, den Sie löschen möchten.
API-Format
DELETE /config/schedules/{SCHEDULE_ID}
{SCHEDULE_ID}
id
-Wert des Zeitplans, den Sie löschen möchten.Anfrage
code language-shell |
---|
|
Antwort
Bei erfolgreicher Antwort wird der HTTP-Status-Code 204 (kein Inhalt) zurückgegeben.
Nächste Schritte
Nach dem Lesen dieses Handbuchs haben Sie jetzt ein besseres Verständnis davon, wie Zeitpläne funktionieren.
Anhang appendix
Im folgenden Anhang wird das Format der in Zeitplänen verwendeten Cron-Ausdrücke erläutert.
Format
Ein Cron-Ausdruck ist eine Zeichenfolge aus 6 oder 7 Feldern. Der Ausdruck würde etwa wie folgt aussehen:
0 0 12 * * ?
In einer Cron-Ausdruckszeichenfolge stellt das erste Feld die Sekunden, das zweite die Minuten, das dritte Feld die Stunden, das vierte Feld den Tag des Monats, das fünfte Feld den Monat und das sechste Feld den Wochentag dar. Sie können optional auch ein siebtes Feld einfügen, das das Jahr darstellt.
, - * /
, - * /
, - * /
, - * ? / L W
, - * /
, - * ? / L #
, - * /
SUN
der Verwendung von sun
.Die zulässigen Sonderzeichen stehen für die folgende Bedeutung:
*
*
in das Feld "Stunden"eingeben, bedeutet dies jede Stunde.?
3
in das Monatsfeld und ?
in das Wochentag-Feld.-
9-15
in das Feld Stunden eingeben, würden die Stunden 9, 10, 11, 12, 13, 14 und 15 umfassen.,
MON, FRI, SAT
in das Feld Wochentag setzen, würden die Wochentage Montag, Freitag und Samstag umfassen./
/
platzierte Wert bestimmt, von wo er erhöht wird, während der nach dem /
platzierte Wert bestimmt, um wie viel er erhöht wird. Wenn Sie beispielsweise "1/7
"in das Feld "Minuten"setzen, würden die Minuten 1, 8, 15, 22, 29, 36, 43, 50 und 57 umfassen.L
Last
anzugeben, und hat je nachdem, von welchem Feld er verwendet wird, eine andere Bedeutung. Wenn es mit dem Tag des Monats-Felds verwendet wird, stellt es den letzten Tag des Monats dar. Wenn es allein mit dem Wochentag verwendet wird, stellt es den letzten Wochentag dar, nämlich Samstag (SAT
). Wenn es zusammen mit dem Wochentag in Verbindung mit einem anderen Wert verwendet wird, stellt es den letzten Tag dieses Typs für den Monat dar. Wenn Sie beispielsweise 5L
in das Wochentag-Feld eintragen, würde dies nur den letzten Freitag des Monats einschließen.W
18W
"in das Monatsfeld setzen und der 18. dieses Monats einen Samstag war, würde dieser am Freitag, dem 17., der nächstgelegenen Wochentag, Trigger haben. Wenn der 18. des Monats ein Sonntag wäre, würde er am Montag am 19., dem nächstgelegenen Wochentag, Trigger haben. Wenn Sie 1W
in das Monatsfeld eintragen und der nächstgelegene Wochentag im Vormonat liegt, wird das Ereignis weiterhin am nächsten Wochentag des aktuellen Monats Trigger.Außerdem können Sie
L
und W
zu LW
kombinieren, was den letzten Wochentag des Monats angibt.#
#
platzierte Wert stellt den Wochentag dar, während der Wert, der nach dem #
platziert wird, für welches Vorkommen im Monat es sich handelt. Wenn Sie beispielsweise 1#3
setzen, wird das Ereignis am dritten Sonntag des Monats Trigger. Wenn Sie X#5
setzen und dieser Wochentag nicht zum fünften Mal vorkommt, wird das Ereignis nicht ausgelöst. Wenn Sie beispielsweise 1#5
setzen und es keinen fünften Sonntag in diesem Monat gibt, wird das Ereignis nicht ausgelöst.Beispiele
Die folgende Tabelle zeigt Beispiel-Cron-Ausdruckszeichenfolgen und erklärt, was sie bedeuten.
0 0 13 * * ?
0 30 9 * * ? 2022
0 * 18 * * ?
0 0/10 17 * * ?
0 13,38 5 ? 6 WED
0 30 12 ? * 4#3
0 30 12 ? * 6L
0 45 11 ? * MON-THU