Heim >Backend-Entwicklung >PHP-Tutorial >Beste Redis-Caching-Strategie in Laravel: Ein Leitfaden für schnelles und effizientes Caching
Laravel und Redis sind eine leistungsstarke Kombination zur Steigerung der Anwendungsgeschwindigkeit und -leistung. Redis, ein In-Memory-Schlüsselwertspeicher, eignet sich perfekt zum Caching, insbesondere wenn Sie schnellen und häufigen Datenzugriff benötigen. In diesem Leitfaden betrachten wir effektive Caching-Strategien in Laravel mit Redis. Wir behandeln, wie man Daten zwischenspeichert, Ablaufzeiten verwaltet und Caches effizient löscht.
Warum Redis Caching verwenden?
Wenn Sie mit Redis in Laravel zwischenspeichern, speichern Sie Daten im Wesentlichen vorübergehend, um den Zeitaufwand für die Abfrage der Datenbank zu reduzieren. Caching beschleunigt den Datenabruf, reduziert die Serverlast und verbessert die Benutzererfahrung, indem Seiten schneller geladen werden.
Redis eignet sich ideal zum Caching, weil es:
Lassen Sie uns untersuchen, wie Sie Redis-Caching in Laravel am besten nutzen können.
Nehmen wir an, wir haben eine Zeitungsseite. Jetzt müssen wir eine API erstellen, um Nachrichten zu erhalten.
Lassen Sie uns zunächst eine einfache API-Antwort zwischenspeichern, beispielsweise eine Liste der neuesten Nachrichtenartikel.
$data = Cache::remember('latest_news', 3600, function () { return News::latest()->get(); });
In diesem Beispiel:
Cache::remember speichert Daten mit einem Schlüssel (latest_news) und einer Lebensdauer (TTL) von 3600 Sekunden (1 Stunde).
Wenn innerhalb einer Stunde erneut eine Anfrage nach „latest_news“ eingeht, stellt Redis die zwischengespeicherten Daten bereit, ohne die Datenbank abzufragen.
Um die Daten aktuell zu halten, ohne Redis zu überlasten:
Legen Sie kürzere TTLs für häufig aktualisierte Daten fest (z. B. 15–30 Minuten).
Verwenden Sie längere TTLs (z. B. 1–2 Stunden) für Daten, die sich selten ändern.
Verwenden Sie spezifische, strukturierte Cache-Schlüssel, die den Dateninhalt widerspiegeln. Zum Beispiel:
$cacheKey = "news:category:category_1";
Dieser Schlüssel ist klar, eindeutig und selbstbeschreibend, sodass er in Redis leicht identifiziert und verwaltet werden kann.
Redis unterstützt Tags, mit denen wir gruppierte Daten unter einem gemeinsamen Tag verwalten können. Markieren Sie beispielsweise alle nachrichtenbezogenen Caches mit news:
Cache::tags(['news', 'category'])->remember('category_news_1', 3600, function () { return $this->news_repository->getNewsByCategory(1); });
Wenn wir nun alle kategoriespezifischen Nachrichten-Caches löschen möchten (wenn Nachrichten aktualisiert werden), können wir Folgendes verwenden:
Cache::tags(['news', 'category'])->flush();
$page = request()->input('page', 1); $limit = request()->input('limit', 10); $cacheKey = "news:page_{$page}:limit_{$limit}"; $newsData = Cache::remember($cacheKey, 3600, function () use ($page, $limit) { return News::latest()->paginate($limit, ['*'], 'page', $page); });
Hier entlang:
Für jede Seite und jedes Limit wird ein eindeutiger Cache-Eintrag erstellt.
Benutzer können Seiten schnell abrufen, ohne die Datenbank erneut abzufragen.
Fügen Sie für gefilterte Daten die Filterparameter in den Schlüssel ein:
$data = Cache::remember('latest_news', 3600, function () { return News::latest()->get(); });
Dadurch wird sichergestellt, dass jede Kombination aus Kategorie und Seite einen eigenen Cache-Eintrag hat.
Das Löschen oder „Ungültigmachen“ von Caches stellt sicher, dass Benutzer bei Bedarf aktualisierte Daten sehen. So automatisieren Sie es:
Verwenden Sie Modellbeobachter für Ereignisse wie erstellt, aktualisiert oder gelöscht, um zugehörige Caches zu löschen.
Beispielbeobachter für Nachrichten:
$cacheKey = "news:category:category_1";
Sobald Nachrichten hinzugefügt oder aktualisiert werden, werden alle Nachrichten- und Paginierungs-Tag-Caches geleert, sodass die Daten aktuell bleiben.
Damit das Caching effektiv funktioniert:
Eindeutige Schlüssel: Strukturschlüssel mit Parametern wie Kategorie, Seite und Limit.
Tags für gruppierte Daten: Verwenden Sie Tags, um Caches für bestimmte Datengruppen einfach zu verwalten.
Automatisieren Sie die Invalidierung: Richten Sie Beobachter ein, um veraltete Caches bei Datenänderungen zu löschen.
Legen Sie einen sinnvollen Ablauf fest: Wählen Sie TTLs basierend darauf, wie oft sich die Daten ändern, normalerweise zwischen 15 Minuten und 1 Stunde.
Durch die Verwendung von Redis mit diesem strukturierten Ansatz reagieren Laravel-APIs schneller, verbessert die Serverlastverwaltung und gewährleistet eine zuverlässige, effiziente Cache-Strategie, die einfach zu verwalten ist.
Das obige ist der detaillierte Inhalt vonBeste Redis-Caching-Strategie in Laravel: Ein Leitfaden für schnelles und effizientes Caching. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!