安装
composer require rennokki/laravel-eloquent-query-cache
引用
use Rennokki\QueryCache\Traits\QueryCacheable;
use QueryCacheable;
默认情况下启动缓存行为
Model 中定义
protected $cacheFor = 180; // 3 minutes
每当执行一个查询时,缓存将会干预。如果此查询在缓存中为空,那么会去数据库中获取数据,并且缓存它,以便下次可以从缓存中获取。如果此查询存在于缓存中,那么直接返回。
// 数据库访问,查询结果存储在缓存中
Article::latest()->get();// 未访问数据库,查询结果直接从缓存中返回。
Article::latest()->get();
如果你只是想要避免命中缓存,你可以在命中最后一个方法之前使用 ->dontCache() 。
Article::latest()->dontCache()->firstOrFail();
启用逐个查询的缓存行为
另一种方法是,如果默认情况下的缓存机制并不是太好的选择,你可以启用逐个查询的缓存。
首先,从模型中移除变量$cacheFor。
对于每个查询,你可以调用 ->cacheFor(...)方法去指定你想缓存的那个查询。
Article::cacheFor(now()->addHours(24))->paginate(15);
用 tags 更好地组织缓存
一些缓存存储,像 Redis 或者 Memcached,提供了对 key 的标记支持。这很有用,因为我们可以在缓存中标记查询,并在需要时再通过 tag 使所需的缓存失效。 举一个简单的例子,如果我们要在更新一篇文章时使文章列表不进行缓存,你可以像这样写。
$articles= Article::cacheFor(60)->cacheTags(['latest:articles'])->latest()->get();
$article= Article::find($id);
$article->update(['title'=>'My new title']);
Article::flushQueryCache(['latest:articles']);
flushQueryCache方法使用 latest:articles标记使缓存无效。如果其他的一些查询中没有被 latest:articles标记,那么将被保留缓存。
网友评论