今天就跟大家聊聊有关如何在Laravel中使用Model层做数据缓存,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
十多年专注成都网站制作,成都企业网站建设,个人网站制作服务,为大家分享网站制作知识、方案,网站设计流程、步骤,成功服务上千家企业。为您提供网站建设,网站制作,网页设计及定制高端网站建设服务,专注于成都企业网站建设,高端网页制作,对混凝土搅拌罐车等多个方面,拥有丰富的网站维护经验。假设你有很多个Comment
的 Article
模型,给定下面的Laravel blade 模板,你就可以像下面这样访问 /article/:id
路由时得到评论的数量:
$article->comments->count() {{ str_plural('Comment', $article->comments->count())
您可以在控制器中缓存评论的计数,但是当您有多个需要缓存的一次性查询和数据时,控制器会变得非常臃肿难看。使用控制器,访问缓存的数据也不是很方便。
我们可以构建一个模板,它仅在文章更新时访问数据库,并且访问该模型的所有代码都可以获取缓存值:
$article->cached_comments_count {{ str_plural('Comment', $article->cached_comments_count)
通过使用模型访问器,我们可以缓存基于最后一次文章更新的评论计数值。
因此,在评论新增或删除时我们该怎么更新文章的 updated_at
列值呢?
先进入 touch 方法看看。
模型的触发
可以通过使用模型的 touch()
方法来更新文章的 updated_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
我们可以用更新的 timestamp 值使缓存失效。不过在新增或删除一个评论时,我们怎么触发修改文章的 updated_at
字段呢?
碰巧 Eloquent 模型中有一个属性就叫 $touches
。下面是我们的评论模型的大概样子:
belongsTo(Article::class); } }
这里的 $touches
属性是个数组,包含了在评论的创建、保存和删除时会引起“触发”的关联信息。
缓存的属性
我们先回到 $article->cached_comments_count
访问器。该方法的实现可能象 App\Article
模型中的样子:
public function getCachedCommentsCountAttribute() { return Cache::remember($this->cacheKey() . ':comments_count', 15, function () { return $this->comments->count(); }); }
我们使用键值的 cacheKey()
方法缓存模型 15 分钟,然后简单地在闭包方法中返回评论计数值。
注意,我们也用到了 Cache::rememberForever()
方法,靠着缓存机制的垃圾回收策略以删除过期的键值。我设置了一个定时器,以便在每隔 15 分钟的缓存刷新间隔里,缓存可在该时间的多数范围内有高的命中率。
cacheKey()
方法要用到模型的键值,并且在模型更新时对应缓存失效。下面是我的 cacheKey
实现代码:
public function cacheKey() { return sprintf( "%s/%s-%s", $this->getTable(), $this->getKey(), $this->updated_at->timestamp ); }
模型的 cacheKey()
方法示例输出结果可能返回下面的字串信息:
articles/1-1515650910
这个键值是由表名、模型id值及当前 updated_at
的 timestamp 值组成。一旦我们触发这个模型,timestamp 值就会更新,并且我们的模型缓存就会相应地失效。
以下是 Article
模型的完整代码:
getTable(), $this->getKey(), $this->updated_at->timestamp ); } public function comments() { return $this->hasMany(Comment::class); } public function getCachedCommentsCountAttribute() { return Cache::remember($this->cacheKey() . ':comments_count', 15, function () { return $this->comments->count(); }); } }
然后是关联的 Comment
模型:
belongsTo(Article::class); } }
接下来做什么?
我已经向你展示了如何缓存一个简单的评论计数,但是如何缓存所有的评论呢?
public function getCachedCommentsAttribute() { return Cache::remember($this->cacheKey() . ':comments', 15, function () { return $this->comments; }); }
你也可以选择将评论转换为数组替代序列化模型,只允许在前端对数据进行简单的数组访问:
public function getCachedCommentsAttribute() { return Cache::remember($this->cacheKey() . ':comments', 15, function () { return $this->comments->toArray(); }); }
看完上述内容,你们对如何在Laravel中使用Model层做数据缓存有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。