>백엔드 개발 >PHP 튜토리얼 >Laravel 최고의 Redis 캐싱 전략: 빠르고 효율적인 캐싱 가이드

Laravel 최고의 Redis 캐싱 전략: 빠르고 효율적인 캐싱 가이드

DDD
DDD원래의
2024-11-12 09:29:02650검색

Best Redis Caching Strategy in Laravel: A Guide to Fast and Efficient Caching

Laravel과 Redis는 애플리케이션 속도와 성능을 향상시키는 강력한 조합입니다. 인메모리 키-값 저장소인 Redis는 특히 빠르고 빈번한 데이터 액세스가 필요한 경우 캐싱에 적합합니다. 이 가이드에서는 Redis를 사용하는 Laravel의 효과적인 캐싱 전략을 살펴보겠습니다. 데이터를 캐시하고, 만료 시간을 관리하고, 효율적으로 캐시를 지우는 방법을 다룹니다.

Redis 캐싱을 사용하는 이유
Laravel에서 Redis를 사용하여 캐시하면 기본적으로 데이터베이스 쿼리에 소요되는 시간을 줄이기 위해 데이터를 일시적으로 저장하게 됩니다. 캐싱은 데이터 검색 속도를 높이고 서버 로드를 줄이며 페이지 로드 속도를 높여 사용자 경험을 향상시킵니다.

Redis는 다음과 같은 이유로 캐싱에 이상적입니다.

  • 빠른 데이터 저장 및 검색 가능
  • 문자열, 목록, 해시 등 다양한 데이터 구조 지원
  • 캐시 만료를 관리하고 오래된 데이터를 삭제하는 도구 제공

Laravel에서 Redis 캐싱을 가장 효과적으로 사용하는 방법을 살펴보겠습니다.
뉴스 신문 사이트가 있다고 가정해 보겠습니다. 이제 뉴스를 받기 위한 API를 구축해야 합니다.

1. Laravel 및 Redis를 사용하여 기본 캐싱 설정

먼저 최신 뉴스 기사 목록과 같은 간단한 API 응답을 캐시해 보겠습니다.

$data = Cache::remember('latest_news', 3600, function () {
    return News::latest()->get();
});

이 예에서는:
Cache::remember는 키(latest_news)와 3600초(1시간)의 TTL(Time to Live)을 사용하여 데이터를 저장합니다.
한 시간 내에 최신 뉴스에 대한 요청이 다시 들어오면 Redis는 데이터베이스를 쿼리하지 않고 캐시된 데이터를 제공합니다.

2. 캐시 키 및 만료 시간 구조화

Redis에 과부하를 주지 않고 데이터를 최신 상태로 유지하려면:
자주 업데이트되는 데이터의 경우 TTL을 더 짧게 설정하세요(예: 15~30분).
거의 변경되지 않는 데이터에는 더 긴 TTL(예: 1~2시간)을 사용하세요.

데이터 콘텐츠를 반영하는 구체적이고 구조화된 캐시 키를 사용하세요. 예:

$cacheKey = "news:category:category_1";

이 키는 명확하고 고유하며 자기 설명적이므로 Redis 내에서 쉽게 식별하고 관리할 수 있습니다.

3. 그룹화된 캐시 관리를 위해 태그 사용

Redis는 공통 태그로 그룹화된 데이터를 관리할 수 있는 태그를 지원합니다. 예를 들어, 뉴스와 관련된 모든 캐시에 다음과 같이 태그를 지정합니다.

Cache::tags(['news', 'category'])->remember('category_news_1', 3600, function () {
    return $this->news_repository->getNewsByCategory(1);
});

이제 모든 카테고리별 뉴스 캐시를 지우려면(뉴스가 업데이트될 때) 다음을 사용할 수 있습니다.

Cache::tags(['news', 'category'])->flush();
  1. 페이지를 매기고 필터링된 데이터 캐싱 페이지 매김 또는 필터(예: 카테고리 또는 태그)를 추가할 때 각 캐시 키를 매개변수에 고유하게 만드세요.
$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);
});

이 방법:
각 페이지와 한도에 대해 고유한 캐시 항목이 생성됩니다.
사용자는 데이터베이스를 다시 쿼리하지 않고도 페이지를 빠르게 가져올 수 있습니다.

필터링된 데이터의 경우 키에 필터 매개변수를 포함하세요.

$data = Cache::remember('latest_news', 3600, function () {
    return News::latest()->get();
});

이렇게 하면 각 카테고리와 페이지 조합에 고유한 캐시 항목이 있습니다.

5. 데이터 변경 시 자동 캐시 무효화

캐시를 지우거나 "무효화"하면 필요할 때 사용자가 업데이트된 데이터를 볼 수 있습니다. 자동화하는 방법은 다음과 같습니다.
관련 캐시를 지우려면 생성, 업데이트 또는 삭제와 같은 이벤트에 모델 관찰자를 사용하세요.
뉴스 관찰자의 예:

$cacheKey = "news:category:category_1";

이제 뉴스가 추가되거나 업데이트될 때마다 모든 뉴스와 페이지 매김 태그 캐시가 플러시되어 데이터를 최신 상태로 유지합니다.

6. 요약 및 모범 사례

캐싱 작업을 효과적으로 수행하려면:
고유 키: 카테고리, 페이지, 제한과 같은 매개변수가 포함된 구조 키.
그룹화된 데이터용 태그: 태그를 사용하여 특정 데이터 그룹에 대한 캐시를 쉽게 관리할 수 있습니다.
무효화 자동화: 데이터 변경 시 오래된 캐시를 지우도록 관찰자를 설정합니다.
합리적인 만료 설정: 데이터 변경 빈도에 따라 TTL을 선택합니다(일반적으로 15분에서 1시간 사이).

이 구조화된 접근 방식으로 Redis를 사용하면 Laravel API가 더 빠르게 응답하고, 서버 로드 관리를 개선하며, 관리하기 쉬운 안정적이고 효율적인 캐시 전략을 보장합니다.

위 내용은 Laravel 최고의 Redis 캐싱 전략: 빠르고 효율적인 캐싱 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.