前言
本文主要给大家介绍了关于Redis在Laravel项目中的应用实例,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:
在初步了解Redis在Laravel中的应用 那么我们试想这样的一个应用场景 一个文章或者帖子的浏览次数的统计 如果只是每次增加一个浏览量
就到数据库新增一个数据 如果请求来那个太大这对数据库的消耗也就不言而喻了吧 那我们是不是可以有其他的解决方案
这里的解决方案就是 即使你的网站的请求量很大 那么每次增加一个访问量就在缓存中去进行更改 至于刷新MysqL数据库可以自定义为
多少分钟进行刷新一次或者访问量达到一定数量再去刷新数据库 这样数据也是准确的 效率也比直接每次刷新数据库要高出许多了
既然给出了相应的解决方案 我们就开始实施
我们以一篇帖子的浏览为例 我们先去创建对应的控制器
rush:
PHP;">
$
PHP artisan make:controller PostController
再去生成需要用到的 Model
rush:
PHP;">
$
PHP artisan make:model Post -m
填写posts的迁移表的字段内容
increments('id');
$table->string("title");
$table->string("content");
$table->integer('view_count')->unsigned();
$table->timestamps();
});
还有就是我们测试的数据的Seeder填充数据
define(App\Post::class,function (Faker\Generator $faker) {
return [
'title' => $faker->sentence,'content' => $faker->p
aragraph,'view_count' => 0
];
});
定义帖子的访问路由
rush:
PHP;">
Route::get('/post/{id}','PostController@showPost');
当然我们还是需要去写我们访问也就是浏览事件的(在app/providers/EventServiceProvider中定义)
[
// 'App\Listeners\EventListener','App\Listeners\PostEventListener',],];
执行事件生成监听
rush:
PHP;">
$
PHP artisan event:generate
之前定义了相关的路由方法 现在去实现一下:
cacheExpires,function () use ($id) {
return Post::whereId($id)->f
irst();
});
//获取客户端请求的IP
$ip = $request->ip();
//触发浏览次数统计时间
event(new PostViewEvent($post,$ip));
return view('posts.show',compact('post'));
}
这里看的出来就是以Redis作为缓存驱动 同样的 会获取获取的ip目的是防止同一个ip多次刷新来增加浏览量
同样的每次浏览会触发我们之前定义的事件 传入我们的post和id参数
Redis的key的命名以:分割 这样可以理解为一个层级目录 在可视化工具里就可以看的很明显了
接下来就是给出我们的posts.show的视图文件
rush:xhtml;">
<
Meta charset="utf-8">
<
Meta http-equiv="X-UA-Compatible" content="IE=edge">
<
Meta name="viewport" content="width=device-width,initial-scale=1">
Bootstrap Template
Title:{{$post->title}}
view_count}} views
Content:{{$post->content}}