Voici un bon article sur la mise en cache de sortie: http://www.4guysfromrolla.com/articles/121306-1.aspx.
Généralement, vous semblez regarder la mise en cache des pages et des fragments. Ce que vous voulez faire est de mettre en cache la page, si vous le pouvez, car cela vous donnera le meilleur avantage de performance. Mais, si vous avez des régions sur la page qui doivent changer dynamiquement par utilisateur, par exemple: vous dites 'Bonjour {nom d'utilisateur}' en haut de la page, alors vous devez regarder la mise en cache des fragments.
La mise en cache des fragments n'est pas aussi efficace que la mise en cache des pages, car la sortie doit être assemblée à partir des informations mises en cache et des informations dynamiques, mais généralement beaucoup mieux que la mise en cache!
C'est un peu un art de modifier la mise en cache en fonction de ce que fait la page et de la charge sur la base de données, mais cela peut rendre une page chargée plus rapidement que non mise en cache. FYI - Si les requêtes db détruisent le site, vous pouvez également essayer de les apprivoiser et/ou mettre en cache leur sortie individuellement, de sorte que vous n'ayez pas besoin de continuer à utiliser la même base de données. Comprendre aussi le 'varyByParam' pour la mise en cache est très utile aussi - disons que vous avez une page en 3 langues, vous pouvez mettre en cache une page pour chaque langue en utilisant le varyByParam, aussi longtemps que votre Url une sorte de composant de langue le varyByParam peut ramasser.
HTH, Lance
Voilà ce que je pensais, parce que c'est le seul senario qui fait des sens –