Sie sind hier: Wissen
Werbung Werbung

Was ist Seiten-Caching in ASP.NET (Outout-Caching) ?

Bei Aufruf einer ASP.NET-Webforms-Website wird viel Programmcode ausgeführt. Nachdem die Steuerelemente instanziiert wurden, Skin- und Ressourcen-Dateien berücksichtigt wurden und der HTTP-Request inklusive Viewstate ausgewertet wurden, werden zahlreiche Ereignisse gefeuert in denen (umfangreicher) Programmcode liegen kann. Manchmal ändern sich aber Inhalte einer Website gar nicht so häufig. Einige Sekunden oder gar Minuten lang kann man immer dieselbe Ausgabe liefert. ASP.NET Webforms bieten hier einen einfach anzuwendenden Mechanismus zur Zwischenspeicherung der „gerenderten“ Seiten.

Grundsätzlich ist zu prüfen, ob die Benutzer des Systems immer den letzten Stand der Daten sehen müssen oder ob ein Stand, der wenige Sekunden bzw. Minuten oder Stunden zurückliegt, nicht ausreichend ist. Oftmals fordern Benutzer den »top-aktuellen« Stand. Tatsächlich kann in einigen Fällen darauf aber verzichtet werden und der Server bzw. die Serverfarm dann kleiner ausfallen, weil weniger Rechenleistung gebraucht wird.

Dem Output-Caching handelt es sich um einen in ASP.NET Webforms eingebauten Mechanismus zur Optimierung der Leistung durch das Vorhalten von Webseiten, die bereits zu einem früheren Zeitpunkt angefordert wurden. Bei der Seitenzwischenspeicherung werden ganze Seiten auf dem Webserver vorrätig gehalten, ohne sie bei jedem Aufruf dynamisch zu erzeugen. Normalerweise verwirft der Webserver die Ausgabe sofort nach der Weiterleitung an den Webclient.

Im Rahmen einer Seitendirektive (<%@OutputCache> direkt unterhalb von <%@Page>) kann definiert werden, dass die Ausgabe eine definierbare Zeit lang im Speicher zur Beantwortung gleichartiger Anfragen vorgehalten wird. Ob zwei Anfragen als »gleich« betrachtet werden, kann dabei definiert werden. So lässt sich beispielsweise festlegen, dass die übergebenen Parameter berücksichtigt werden (die Seiten also für jede Parameterkombination einzeln zwischengespeichert werden) oder dass zwei unterschiedliche Browser bzw. Browserversionen nicht den gleichen HTML-Code erhalten (die Seiten also für jeden Browser einzeln zwischengespeichert werden).

Das Verhalten und die Regeln für das Unterdrücken der Neuerzeugung einer Webseite können über die @OutputCache-Direktive flexibel konfiguriert werden. So ist es z. B. über die Parameter VaryByParamoder VaryByCustom möglich, abhängig von übertragenen Parametern oder Browsern unterschiedliche Versionen ein und derselben Webseite vorrätig zu halten.

Die Seitendirektive

<%@ OutputCache
Duration="30"
VaryByParam="Abflugort;Zielort" %>

sorgt für die Zwischenspeicherung für 30 Sekunden. Eigene Zwischenspeicher werden in Abhängigkeit von den Querystring-Parametern „Abflugort“ und „Zielort“ gebildet.

Die Seitendirektive

<%@ OutputCache
Duration="90"
VaryByParam="*"
VaryByCustom="browser" %>

sorgt für die Zwischenspeicherung für 90 Sekunden. Alle übergebenen Parameter haben Einfluss auf den Seiteninhalt und es gibt auch für jeden Browsertyp eine eigene zwischengespeicherte Seite.

Caching-Profile

Mit ASP.NET 2.0 wurde die Möglichkeit eingeführt, dass der Entwickler in der web.config-Datei Zwischenspeicherungsprofile für die Seitenzwischenspeicherung definieren kann, die er über ihren Namen auf Seiten anwenden kann. Das folgende Fragment aus der web.config zeigt die Definition eines Zwischenspeicherungsprofils für browserabhängige Zwischenspeicherung für 60 Sekunden mit dem Namen „BrowserCacheProfil“.
<caching>
<outputCacheSettings>
<outputCacheProfiles>
<add name="BrowserCacheProfil"
duration="90"
varyByCustom="browser"
location="Server" />
</outputCacheProfiles>
</outputCacheSettings>
</caching>

Dieses Profil „BrowserCacheProfil“ kann dann mit folgender Seitendirekte verwendet werden:
<%@ OutputCache CacheProfile="BrowserCacheProfil" %>

Caching einzelner Steuerelemente

Steuerelemente (sowohl Custom Controls als auch User Controls) können eigene Anweisungen für das Caching besitzen. User Controls erlauben es auch, die auf Seitenebene verwendete @OutputCache-Direktive zur Definition des Caching-Verhaltens einzusetzen. Für User Controls stehen über die @OutputCache-Direktive die gleichen Zwischenspeichermöglichkeiten zur Verfügung, wie sie für ganze Web Forms möglich sind.
Damit die Daten innerhalb eines Benutzersteuerelements im Zwischenspeicher vorgehalten und nicht bei jeder Verwendung neu erstellt werden müssen, reicht die Verwendung der @OutputCache-Direktive:

<%@ OutputCache Duration="60" VaryByParam="*" %>

Gegenüber der @OutputCache-Direktive auf Seitenebene gibt es hier ein weiteres Attribut: VaryByControl. Dieses Attribut darf eine Liste von Attributen des Steuerelements enthalten, die Einfluss darauf hat, ob zwei Seiten in Bezug auf das Caching gleich sind.

Das folgende User Control wird für 10 Minuten im Zwischenspeicher gehalten (Duration="600") und in dieser Zeit nicht neu generiert:

<%@ Control Language="c#" AutoEventWireup="false" CodeFile="SeitenInformation.ascx.cs"
Inherits="SeitenInformation"%>
<%@ OutputCache Duration="600" VaryByParam="none" %>
<hr width="80%">
<P align="center">Letzes Mal aktualisiert:
<asp:Label id="LetztesUpdate" runat="server"></asp:Label></P>

Alternativ zum Einsatz der @OutputCache-Direktive kann die Annotation auf die Hintergrundcodeklasse angewendet werden. Bei Custom Controls steht nur diese Möglichkeit zur Verfügung, da es bei diesen selbsterstellten Steuerelementen keine Datei mit Deklarationen gibt, in der man eine Seitendirektive unterbringen könnte.
[System.Web.UI.PartialCaching(600, "none", "", "")]
public class PostBackZaehler : WebControl { …

Auf großen Webseiten mit vielen Daten, die bei jedem Aufruf neu erstellt werden müssen, und einem ähnlich großen Anteil an Daten, die nur selten oder weniger häufig aktualisiert werden, ist es sinnvoll, die seltener zu aktualisierenden Daten in ein User Control oder Custom Control auszulagern und dort die @OutputCache-Direktive bzw. die Annotation [System.Web.UI.PartialCaching] zu verwenden.

Beratung & Support

Schulungen zu diesem Thema

 Anfrage für eine individuelle Schulung zum Thema Seiten-Caching in ASP.NET (Outout-Caching)  Gesamter Schulungsthemenkatalog

Bücher zu diesem Thema

  .NET 9.0 Update: Die Neuerungen in .NET 9.0 gegenüber .NET 8.0
  PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
  .NET 8.0 Update: Die Neuerungen in .NET 8.0 gegenüber .NET 7.0
  Blazor 8.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 8.0, C# 12.0 und Visual Studio 2022
  Moderne Datenzugriffslösungen mit Entity Framework Core 8.0
  C# 12.0 Crashkurs
  Cross-Plattform-Apps mit .NET MAUI entwickeln
  Blazor 7.0: Blazor WebAssembly, Blazor Server und Blazor Hybrid
  C# 11.0 Crashkurs
  Moderne Datenzugriffslösungen mit Entity Framework Core 7.0
  PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
  App Engineering: SwiftUI, Jetpack Compose, .NET MAUI und Flutter
  Vue.js 3 Crashkurs
  Moderne Datenzugriffslösungen mit Entity Framework Core 6.0
  Blazor 6.0: Blazor WebAssembly, Blazor Server und Blazor Desktop
  C# 10.0 Crashkurs
  Cross-Plattform-Apps mit Xamarin.Forms entwickeln
  Developing Web Components with TypeScript: Native Web Development Using Thin Libraries
  PowerShell – kurz & gut
  C# 9.0 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET 5.0, .NET Core und Xamarin
  ASP.NET Core Blazor 5.0: Blazor WebAssembly und Blazor Server - Moderne Single-Page-Web-Applications
  Windows PowerShell 5 und PowerShell 7: Das Praxisbuch
  Moderne Datenzugriffslösungen mit Entity Framework Core 5.0
  ASP.NET Core Blazor 3.1/3.2: Blazor Server und Blazor Webassembly - Moderne Single-Page-Web-Applications mit .NET, C# und Visual Studio
  ASP.NET Core Blazor 3.0/3.1: Blazor Server und Blazor Webassembly - Moderne Single-Page-Web-Applications mit .NET, C# und Visual Studio
  Moderne Datenzugriffslösungen mit Entity Framework Core 3.1
  C# 8.0 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
  Moderne Datenzugriffslösungen mit Entity Framework Core 3.0
  Windows PowerShell 5.1 und PowerShell Core 6.1 - Das Praxishandbuch
  Moderne Datenzugriffslösungen mit Entity Framework Core 2.1/2.2
  Moderne Webanwendungen für .NET-Entwickler: Server-Anwendungen, Web APIs, SPAs & HTML-Cross-Platform-Anwendungen mit ASP.NET, ASP.NET Core, JavaScript
  C# 7.3 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
  Modern Data Access with Entity Framework Core: Database Programming Using .NET, .NET Core, UWP, and Xamarin with C#
  Windows PowerShell und PowerShell Core - Der schnelle Einstieg: Skriptbasierte Systemadministration für Windows, Linux und macOS
  Programmierung in Python
  C# 7.2 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
  Moderne Datenzugriffslösungen mit Entity Framework Core 2.0/2.1
  Effizienter Datenzugriff mit Entity Framework Core: Datenbankprogrammierung mit C# für .NET Framework, .NET Core und Xamarin
  Moderne Datenzugriffslösungen mit Entity Framework Core 2.0
  Windows PowerShell 5 und PowerShell Core 6 - Das Praxishandbuch
  Angular - Das Praxisbuch zu Grundlagen und Best Practices
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.0, 1,1 und 2.0
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.0, 1,1 und 2.0
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.1 und 2.0-Preview2
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.x und 2.0
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.x und 2.0
  Introducing Regular Expressions: JavaScript and TypeScript
  Introducing Web Development
  Introducing Bootstrap 4
  Programming Web Applications with Node, Express and Pug
  Einführung in TypeScript: Grundlagen der Sprache TypeScript 2
  Pug – Die Template-Engine für node.js
  Web-Programmierung mit Node, Express und Pug
  Windows PowerShell 5 – kurz & gut
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.1
  Windows PowerShell 5.0 - Das Praxishandbuch
  PHP 7 und MySQL: Von den Grundlagen bis zur professionellen Programmierung
  Windows Scripting Lernen
  .NET Praxis - Tipps und Tricks für .NET und Visual Studio
  Grundlagen für Web-Entwickler: Protokolle, HTML und CSS
  Bootstrap 3 - Stile und Komponenten
  Bootstrap 4 - Stile und Komponenten
  Einführung in JavaScript: ECMAScript 5
  Einführung in node.js
  express – Middleware für node.js
  JADE – Die Template Engine für node.js
  Reguläre Ausdrücke in JavaScript
  Moderne Datenzugriffslösungen mit Entity Framework 6
  C++ Standardbibliothek
  AngularJS: Moderne Webanwendungen und Single Page Applications mit JavaScript
  Microsoft SharePoint Server 2013 und SharePoint Foundation: Das umfassende Handbuch
  SQL Server 2014 für Professionals: Hochverfügbarkeit, Cloud-Szenarien, Backup/Restore, Monitoring & Performance
  Moderne Webanwendungen mit ASP.NET MVC und JavaScript
  Windows PowerShell 4.0 - Das Praxishandbuch
  JavaScript: Das umfassende Handbuch, inkl. HTML5, JavaScript-Frameworks, jQuery, OOP
  C++11 für Programmierer
  C++ kurz und gut
  Microsoft ASP.NET 4.5 - Entwicklerbuch
  Moderne Webanwendungen mit ASP.NET MVC
  Verteilte Systeme und Services mit .NET 4.5
  Scripting mit Windows PowerShell 3.0 - Der Workshop: Skript-Programmierung mit Windows PowerShell 3.0 vom Einsteiger bis zum Profi
  Windows 8 für Administratoren
  Windows 8.1 - Das Handbuch (27. November 2013)
  Windows Store Apps entwickeln mit C# und XAML - Crashkurs
  .NET 4.5 Update
  Windows Scripting Lernen
  WPF 4.5 und XAML
  Datenbankprogrammierung mit .NET 4.5
  C++11: Der Leitfaden für Programmierer zum neuen Standard
  Verteilte Systeme und Services mit .NET 4.0
  Microsoft ASP.NET 4.0 mit C# 2010 - Entwicklerbuch
  Agile Software Engineering with Visual Studio
  Datenbankprogrammierung mit .NET 4.0. Mit Visual Studio 2010 und SQL Server 2008 R2
  Microsoft SharePoint Server 2010 und SharePoint Foundation 2010
  Microsoft SQL Server 2008 R2 - Das Entwicklerbuch
  Microsoft Viusal C# 2010
  Office 2010 Programmierung mit VSTO und .NET 4.0: Word, Excel und Outlook erweitern und anpassen
  Programmieren mit dem ADO.NET Entity Framework
  .NET 4.0 Crashkurs
  Visual Basic 2010: Grundlagen, ADO.NET, Windows Presentation Foundation
  .NET 4.0 Update
  Windows PowerShell 2.0 - Das Praxishandbuch
  Windows 7 im Unternehmen
  Agile Muster und Methoden
  Ajax
  ASP.NET 4.0
  ASP.NET 4.0 mit Visual C# 2010
  JavaScript
  PHP 5-Migration
  Scripting mit Windows PowerShell 2.0 - Der Einsteiger-Workshop
  SQL Server 2008 R2: Das Programmierhandbuch. Inkl. ADO.NET 3.5, LINQ to Entities und LINQ to SQL
  Visual Basic 2010
  Windows PowerShell 2.0 - Crashkurs
  Windows Server 2008 R2
  Windows Scripting
  Windows Scripting Lernen
  Data Mining mit Microsoft SQL Server
  Windows 7 für Administratoren
  Microsoft ASP.NET 3.5 mit Visual Basic 2008 - Entwicklerbuch
  .NET 3.5
  Essential PowerShell
  .NET 3.5 Crashkurs
  Webanwendungen mit ASP.NET 3.5 und AJAX Crashkurs
 Alle unsere aktuellen Fachbücher  E-Book-Abo für ab 99 Euro im Jahr