Laravel의 모델 계층에서 데이터를 캐시하는 방법은 무엇입니까?

Guanhui
풀어 주다: 2020-06-11 09:21:07
앞으로
3269명이 탐색했습니다.

Laravel의 모델 계층에서 데이터를 캐시하는 방법은 무엇입니까?

이전에도 모델 데이터를 캐싱해 보셨을 텐데요, 이번에는 제가 처음 RailsCast 작업을 시작했을 때 배운 동적으로 로그된 모델을 사용하여 보다 정교한 Laravel 모델 캐싱 기술을 보여드리겠습니다.

모델의 고유한 캐시 키를 사용하면 모델(또는 관련 모델)이 업데이트될 때 자동으로 업데이트되는(그리고 캐시가 무효화되는) 모델의 속성과 연결을 캐시할 수 있습니다. 이점은 캐시된 데이터에 액세스하는 것이 컨트롤러의 데이터는 단일 컨트롤러 방식이 아닌 모델에 있으므로 재사용이 더 쉽습니다.

이 기술의 핵심은 다음과 같습니다.

다음 Laravel 블레이드 템플릿이 주어지면 많은 댓글 기사 모델이 있다고 가정하고 다음과 같이 /article/:id 경로에 액세스할 때 댓글 수를 얻을 수 있습니다.

<h3>$article->comments->count() {{ str_plural(&#39;Comment&#39;, $article->comments->count())</h3>
로그인 후 복사

컨트롤러에서 주석 수를 캐시할 수 있지만 캐시해야 하는 일회성 쿼리와 데이터가 여러 개 있는 경우 컨트롤러가 매우 비대해지고 보기 흉해질 수 있습니다. 컨트롤러를 사용하면 캐시된 데이터에 액세스하는 것도 그리 편리하지 않습니다.

기사가 업데이트될 때만 데이터베이스에 액세스하는 템플릿을 구축할 수 있으며, 모델에 액세스하는 모든 코드는 캐시된 값을 얻을 수 있습니다.

<h3>$article->cached_comments_count {{ str_plural(&#39;Comment&#39;, $article->cached_comments_count)</h3>
로그인 후 복사

모델 접근자를 사용하면 마지막 업데이트를 기준으로 댓글 수를 캐시할 수 있습니다. 기사 업데이트 값.

그렇다면 댓글이 추가되거나 삭제될 때 기사의 update_at 컬럼 값을 어떻게 업데이트해야 할까요?

먼저 터치 방식을 입력해 보세요.

모델 트리거

모델의 touch() 메서드를 사용하여 기사의 update_at 열 값을 업데이트할 수 있습니다.

$ php artisan Tinker

>>> $article = \App\Article::first();
=> App\Article {#746
     id: 1,
     title: "Hello World",
     body: "The Body",
     created_at: "2018-01-11 05:16:51",
     updated_at: "2018-01-11 05:51:07",
   }
>>> $article->updated_at->timestamp
=> 1515649867
>>> $article->touch();
=> true
>>> $article->updated_at->timestamp
=> 1515650910
로그인 후 복사

업데이트된 타임스탬프 값으로 캐시를 무효화할 수 있습니다. 하지만 댓글을 추가하거나 삭제할 때 기사의 update_at 필드 수정을 어떻게 트리거합니까?

Eloquent 모델에는 $touches라는 속성이 있습니다. 댓글 모델은 다음과 같습니다.

<?php
namespace App;
use App\Article;
use Illuminate\Database\Eloquent\Model;
class Comment extends Model
{
    protected $guarded = [];
    protected $touches = [&#39;article&#39;];
    public function article()
    {
        return $this->belongsTo(Article::class);
    }
}
로그인 후 복사
로그인 후 복사

여기서 $touches 속성은 댓글이 생성, 저장 및 삭제될 때 "트리거"를 유발하는 관련 정보가 포함된 배열입니다.

캐시된 속성

먼저 $article->cached_comments_count 접근자로 돌아가 보겠습니다. 이 메소드의 구현은 AppArticle 모델에서 다음과 같을 수 있습니다:

public function getCachedCommentsCountAttribute()
{
    return Cache::remember($this->cacheKey() . &#39;:comments_count&#39;, 15, function () {
        return $this->comments->count();
    });
}
로그인 후 복사

고유 키의 캐시키() 메소드를 사용하여 15분 동안 모델을 캐시한 다음 클로저 메소드에서 리뷰 수를 간단히 반환합니다.

캐시 메커니즘의 가비지 수집 전략에 따라 만료된 키 값을 삭제하기 위해 Cache::rememberForever() 메서드도 사용한다는 점에 유의하세요. 매 15분이라는 캐시 새로 고침 간격 동안 대부분의 시간 동안 캐시의 적중률이 가장 높도록 타이머를 설정했습니다.

cacheKey() 메서드는 모델의 고유 키 값을 사용하며, 모델이 업데이트되면 해당 캐시가 무효화됩니다. 다음은 내 캐시키 구현 코드입니다.

public function cacheKey()
{
    return sprintf(
        "%s/%s-%s",
        $this->getTable(),
        $this->getKey(),
        $this->updated_at->timestamp
    );
}
로그인 후 복사

모델의 캐시키() 메서드 예제 출력은 다음 문자열 정보를 반환할 수 있습니다.

articles/1-1515650910
로그인 후 복사

이 키 값은 테이블 이름, 모델 ID 값 및 타임스탬프 값으로 구성됩니다. 현재 업데이트_at. 이 모델을 트리거하면 타임스탬프 값이 업데이트되고 그에 따라 모델 캐시가 무효화됩니다.

다음은 Article 모델의 전체 코드입니다:

<?php
namespace App;
use App\Comment;
use Illuminate\Support\Facades\Cache;
use Illuminate\Database\Eloquent\Model;
class Article extends Model
{
    public function cacheKey()
    {
        return sprintf(
            "%s/%s-%s",
            $this->getTable(),
            $this->getKey(),
            $this->updated_at->timestamp
        );
    }
    public function comments()
    {
        return $this->hasMany(Comment::class);
    }
    public function getCachedCommentsCountAttribute()
    {
        return Cache::remember($this->cacheKey() . &#39;:comments_count&#39;, 15, function () {
            return $this->comments->count();
        });
    }
}
로그인 후 복사

그리고 관련 Comment 모델:

<?php
namespace App;
use App\Article;
use Illuminate\Database\Eloquent\Model;
class Comment extends Model
{
    protected $guarded = [];
    protected $touches = [&#39;article&#39;];
    public function article()
    {
        return $this->belongsTo(Article::class);
    }
}
로그인 후 복사
로그인 후 복사

다음은 무엇입니까?

간단한 댓글 수를 캐시하는 방법을 설명했지만 모든 댓글을 캐시하는 것은 어떨까요?

public function getCachedCommentsAttribute()
{
    return Cache::remember($this->cacheKey() . &#39;:comments&#39;, 15, function () {
        return $this->comments;
    });
}
로그인 후 복사

모델을 직렬화하는 대신 주석을 배열로 변환하여 프런트엔드의 데이터에 대한 간단한 배열 액세스만 허용할 수도 있습니다.

public function getCachedCommentsAttribute()
{
    return Cache::remember($this->cacheKey() . &#39;:comments&#39;, 15, function () {
        return $this->comments->toArray();
    });
}
로그인 후 복사

마지막으로 Article 모델에서 캐시키() 메서드를 정의했지만 복합 모델에서 사용하거나 기본 모델의 모든 모델 확장에 대한 메서드를 정의할 수 있도록 ProvideModelCacheKey라는 특성으로 이 메서드를 정의할 수 있습니다. 캐시키() 메서드를 구현하는 모델에 대한 계약(인터페이스)을 사용할 수도 있습니다.

추천 튜토리얼: "PHP Tutorial" "Laravel"

위 내용은 Laravel의 모델 계층에서 데이터를 캐시하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:learnku.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿