Für Rest-Abfragen, die keine Daten manipulieren (GET), steht ein Caching-Mechanismus zur Verfügung, der für definierte Parameter das Ergebnis einer REST-Page (also des dahinter liegenden Services mit definierten Parametern) zwischenspeichert. Dies ist vor Allem für performancehungrige oder zeitintensiven Abfragen sinnvoll. Um den Mechanismus zu nutzen, muss in der Tabelle Zwischengespeicherte Antworten
Antwortcache
lediglich ein Datensatz angelegt werden:
Feld | Beschreibung | Beispielwerte für Service “Karte” | optional | |||
---|---|---|---|---|---|---|
Seite | Die REST-Page, für die das Caching definiert wird | nein | ||||
Parameter | Die Parameter für den Service der REST-Page | id, locale | nein | |||
Cache-Dauer | Die Dauer, für die der Cache auf Basis des Zeitstempels aktiv ist. Wird | 1 Tag | nein | Zeitstempel | Der Zeitstempel des aktuellen Caches. Wird automatisch befüllt | ja |
Query-Strings | Hier können Werte als Query-Strings definiert werden, für die durch einen Cron-Job der Cache zeitgesteuert vorgeneriert wird | id=1&locale=de_DE | ja |
Info |
---|
Hinweis: Query-Strings müssen ohne URL-Encoding gepflegt werden. |
Ablauf
Für jeden REST-Request, der per GET im System ankommt, wird die Tabelle Zwischengespeicherte Antworten
Antwortcache
geprüft.
Existiert ein Eintrag mit übereinstimmender REST-Page und übereinstimmenden Parametern, wird der Cache angewandt.
Ist der Cache für die übergebenen Parameter nicht aktiv oder nicht mehr valide (weil der Zeitstempel hinsichtlich der Cache-Dauer abgelaufen ist), wird der Cache er neu aufgebaut. Dabei wird auf dem Server eine Datei mit der Antwort des Services für die definierten Parameter abgelegt und der Zeitstempel wird auf den aktuellen Zeitpunkt gesetztmit einem Ablaufdatum versehen, die der definierten Cache-Dauer entspricht.
Ist der Cache bereits aufgebaut und valide, wird die dem Cache zu Grunde liegende Datei mit der zwischengespeicherten Antwort dem
Antwortcache
ausgelesen und ausgeliefert.
Existiert kein passender Eintrag, wird der Request wie üblich beantwortet, indem der zugeordnete Service mit den übergebenen Parametern aufgerufen wird.
...
Um lange Wartezeiten beim Aufbauen der Caches zu vermeiden, existiert ein Mechanismus, der den Cache für alle Datensätze in der Tabelle Zwischengespeicherte Antworten
Antwortcache
automatisch aufbaut.
Der Cron wird wie folgt definiert:
...
Das Cron-Skript holt alle Einträge aus Zwischengespeicherte Antworten
, deren Cache nicht gesetzt (Zeitstempel leer) oder abgelaufen (Zeitstempel plus Cache-Dauer ist kleiner als der aktuelle Zeitpunkt) ist, und baut den Cache auf, indem der zugeordnete Service mit den gepflegten Parametern aufgerufen und die Antwort auf einer Datei auf dem Server gespeichert wird. Antwortcache
und prüft für jeden gepflegten Parameter-Wert, ob bereits ein Cache existiert. Ist dies nicht der Fall, wird der zu Grunde liegende Service mit den definierten Parameter-Werten aufgerufen und das Ergebnis im Cache gespeichert.
Umgehen des Caches
In Einzelfällen kann es notwendig sein, den Cache zu umgehen, bspw. um zu überprüfen, ob der Antwortcache
aktuell ist. Hierzu kann für alle Services, die per GET aufgerufen werden, der Parameter noCache=1
übergeben werden.
Events
Event | Beschreibung |
---|---|
| Das Event wird beim Ausführen des Cacheaufbaus via Cron-Endpunkt für jeden
Bestehende Subscriber:
|
| Das Event wird beim Ausführen des Cacheaufbaus via Cron-Endpunkt für jeden Query-String aus dem zu Grunde liegenden
Bestehende Subscriber:
|