Hello Urs,
Modeles have a very special cache management, and IMO it’s better not to use them outside of an article content, with <modele123|arg> syntax.
For custom dashboards requiring acute cache management, i use memoization plugin with APCU+cachelab plugin so as to optimize it and refresh only specific caches only when specificaly required. It’s quite a whole new way to manage caching with spip. If you go for it, you’ll have to tweak the parts of your PHP where you want a dedicated behaviour : know what triggers uncaching, know what specific caches have to be renewed. There is no english documentation : see plugins.spip.net/cachelab.html
Without these tools, afaik you ought to use spip out of the box cache management :
- only use dynamic <INCLUDE>so as to keep cache granularity, and never use static#MODELEnor#INCLUDE.
- use #CACHE{0}when required for some specific include. These includes should be as small as possible. Dashboards are usualy in restricted access areas so it might not be a problem to have no cache at all for the more dynamic includes… but dashboards can also be compute intensive or heavy on external http access… so it depends on your use case.
- except when timeout, there is no way to trigger some specific cache refresh : it’s « all caches are to be renewed as soon as something changes in the DB » or « no cache is refreshed because nothing changes ».
- oh yes, there is a way : use var_mode=calculon links or on a « refresh » button
In any cases, you can also use XRay plugin (requires memoization with APCu) so as to grasp what precisely happens with SPIP caches on your site.