Heim >Backend-Entwicklung >PHP-Tutorial >Beste Redis-Caching-Strategie in Laravel: Ein Leitfaden für schnelles und effizientes Caching

Beste Redis-Caching-Strategie in Laravel: Ein Leitfaden für schnelles und effizientes Caching

DDD
DDDOriginal
2024-11-12 09:29:02608Durchsuche

Best Redis Caching Strategy in Laravel: A Guide to Fast and Efficient 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:

  • Kann Daten schnell speichern und abrufen
  • Unterstützt verschiedene Datenstrukturen wie Strings, Listen und Hashes
  • Bietet Tools zum Verwalten des Cache-Ablaufs und zum Löschen alter Daten

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.

1. Einrichten von grundlegendem Caching mit Laravel und Redis

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.

2. Strukturierung von Cache-Schlüsseln und Ablaufzeiten

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.

3. Verwenden von Tags für die gruppierte Cache-Verwaltung

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();
  1. Paginierte und gefilterte Daten zwischenspeichern Stellen Sie beim Hinzufügen von Paginierung oder Filtern (wie Kategorien oder Tags) sicher, dass jeder Cache-Schlüssel für die Parameter eindeutig ist:
$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.

5. Automatische Cache-Ungültigmachung bei Datenänderungen

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.

6. Zusammenfassung und Best Practices

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn