Viele kennen die Situation. Man hat im Entwicklungssystem eine super coole UI5/Fiori App für ein S/4HANA System gebastelt, aber nach dem Import in das Produktivsystem (oder Q-System) geht erstmal gar nix. Target was not found, Type Error, Unknown Setting, Cannot read properties, …
Sehr oft liegen die Gründe der Probleme am Cache! Nicht nur am Browser Cache, auch im SAP Backend gibt es mehrere zu berücksichtigende Caches. Nachfolgend eine Auflistung der Cache Themen, die mir im Zuge meiner Arbeit untergekommen sind.
Eigentlich unglaublich, wie viele Caches man ggf. löschen / invalidieren muss.
Wichtiger Hinweis: Das sind meine persönlichen Erfahrungen, bitte verwendet die Reports oder Transaktionen nur nach vorheriger Prüfung. Es kann durchaus sein, dass der eine oder andere Report obsolet wird oder in gewissen System nicht verwendet werden darf! Ich übernehme keine Garantie, dass die Reports oder Transaktionen in euren Systemen einwandfrei und korrekt funktionieren.
Name | Typ | Erläuterung | Bereich |
/UI5/APP_INDEX_CALCULATE | Report | Ab UI Add-On 2.0+ Sollte periodisch eingeplant sein | UI / App |
/UI2/DELETE_CACHE | Report | Löscht UI2 Services & Target Mapping Caches | UI / App / Lpd |
/IWFND/CACHE_CLEANUP | Transaktion | Clean Frontend OData Cache | GW |
/IWBEP/CACHE_CLEANUP | Transaktion | Clean Backend OData Cache | GW |
ICM Server Cache | Global Invalidieren | UI / App / GW | |
/UI2/INVALIDATE_CLIENT_CACHES | Report | Client Cache Invalidation Fiori Launchpad / Cache Buster | UI / App |
/UI2/INVALIDATE_GLOBAL_CACHES | Report | Invalidiert alle UI2 Caches (Alle Services mit /UI2/*, SHMM, … ) | UI / App |
/UI5/UPD_ODATA_METADATA_CACHE | Report | OData Cache – Cache Buster Tokens | UI / App |
/UI5/UPDATE_CACHEBUSTER | Report | Nur für UI Add-On 1.0 | UI / APP |
CL_SADL_LOAD_AREA | Shared Memory | Shared Memory invalidieren | UI / APP |
/UI2/FLP_DEL_PERSONALIZATION | Report | SAP Fiori Launchpad Personalisierungen | UI / APP |
Browser Cache | IE, Chrome, … Cache | UI / APP |
/UI5/APP_INDEX_CALCULATE
Das ist mein Lieblingsreport in dem Zusammenhang, da er mir in den meisten Fällen immer die Probleme löst. Es gibt einen Applikationsindex und Caching für Apps, Komponenten und Libraries. Dieser Report löscht bzw. invalidiert diese Caches / Indextabellen und ist im Normalfall automatisch eingeplant.
Ich habe jedoch die Erfahrung gemacht, dass nach einem Transport von Änderungen einer UI5 Anwendung, ein explizites Ausführen des Reports für die jeweilige Anwendung notwendig ist.
Weiter Informationen zu dem Report können hier entnommen werden:
- SAP Note – 2449635
- help.sap.com
/UI2/DELETE_CACHE
Hier geht es um das Löschen des UI2 Cache. Dieser kann für einen User oder generell gelöscht werden.
/IWFND/CACHE_CLEANUP und /IWBEP/CACHE_CLEANUP
Invalidiert / Löscht das oData Model (SEGW oder RAP) am Frontend- und Backend-Server.
/UI2/INVALIDATE_CLIENT_CACHES
Dieser Report sollte überhaupt nur in Ausnahmefällen notwendig sein – wenn der UI5 Cache Buster im Einsatz ist. Eine Erklärung zum Report gibt es unter help.sap.com.
/UI2/INVALIDATE_GLOBAL_CACHES
Invalidiert alle globalen UI2 Caches. Bitte die Dokumentation des Reports im System beachten.
/UI5/UPD_ODATA_METADATA_CACHE
Der Report löscht die OData Caches Tokens. Bitte auch hier die Dokumentation des Reports beachten.
/UI5/UPDATE_CACHEBUSTER
Der sorgt dafür, dass der Cache Buster mit dem aktuellsten UI5 Metadaten arbeitet. Der Report ist jedoch nur bei Systemen mit UI Add-On 1.0 einzusetzen. Bei Systemen mit einem höheren UI Add-On Release ist hingegen /UI5/APP_INDEX_CALCULATE zu verwenden.
- SAP Note 2474334
/UI2/FLP_DEL_PERSONALIZATION
Fiori Launchpad Homepages können normalerweise durch den Anwender personalisiert werden. Es können neue Gruppen angelegt werden, Apps entfernt oder hinzugefügt werden. Manchmal ist es notwendig, solche Personalisierungen zurückzusetzen. Beispielsweise nach Änderungen im Fiori Katalog oder einer Fiori Gruppe. Ein Erklärung zu der Funktion ist hier beschrieben.
Sonstiges
Änderungen an Service-Definitionen müssen manchmal manuell in Transportaufträgen aufgenommen und transportiert werden.
Fazit
Es vergeht fast kein Transport wo nicht irgendein Cache ein Problem bereitet. Aber mit dem /UI5/APP_INDEX_CALCULATE bekommt man das meist in den Griff.
Ich werden diesen Blogpost nach und nach um weitere Erkenntnisse in dem Zusammenhang ergänzen.