前言
本文主要給大家介紹了關于Redis在Laravel項目中的應用實例,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹:
在初步了解Redis在Laravel中的應用 那么我們試想這樣的一個應用場景 一個文章或者帖子的瀏覽次數的統(tǒng)計 如果只是每次增加一個瀏覽量
就到數據庫新增一個數據 如果請求來那個太大這對數據庫的消耗也就不言而喻了吧 那我們是不是可以有其他的解決方案
這里的解決方案就是 即使你的網站的請求量很大 那么每次增加一個訪問量就在緩存中去進行更改 至于刷新Mysql數據庫可以自定義為
多少分鐘進行刷新一次或者訪問量達到一定數量再去刷新數據庫 這樣數據也是準確的 效率也比直接每次刷新數據庫要高出許多了
既然給出了相應的解決方案 我們就開始實施
我們以一篇帖子的瀏覽為例 我們先去創(chuàng)建對應的控制器
$ php artisan make:controller PostController
再去生成需要用到的 Model
$ php artisan make:model Post -m
填寫posts的遷移表的字段內容
Schema::create('posts', function (Blueprint $table) { $table->increments('id'); $table->string("title"); $table->string("content"); $table->integer('view_count')->unsigned(); $table->timestamps(); });
還有就是我們測試的數據的Seeder填充數據
$factory->define(App\Post::class, function (Faker\Generator $faker) { return [ 'title' => $faker->sentence, 'content' => $faker->paragraph, 'view_count' => 0 ]; });
定義帖子的訪問路由
Route::get('/post/{id}', 'PostController@showPost');
當然我們還是需要去寫我們訪問也就是瀏覽事件的(在app/providers/EventServiceProvider中定義)
protected $listen = [ 'App\Events\PostViewEvent' => [ // 'App\Listeners\EventListener', 'App\Listeners\PostEventListener', ], ];
執(zhí)行事件生成監(jiān)聽
$ php artisan event:generate
之前定義了相關的路由方法 現在去實現一下:
public function showPost(Request $request,$id) { //Redis緩存中沒有該post,則從數據庫中取值,并存入Redis中,該鍵值key='post:cache'.$id生命時間5分鐘 $post = Cache::remember('post:cache:'.$id, $this->cacheExpires, function () use ($id) { return Post::whereId($id)->first(); }); //獲取客戶端請求的IP $ip = $request->ip(); //觸發(fā)瀏覽次數統(tǒng)計時間 event(new PostViewEvent($post, $ip)); return view('posts.show', compact('post')); }
這里看的出來就是以Redis作為緩存驅動 同樣的 會獲取獲取的ip目的是防止同一個ip多次刷新來增加瀏覽量
同樣的每次瀏覽會觸發(fā)我們之前定義的事件 傳入我們的post和id參數
Redis的key的命名以:分割 這樣可以理解為一個層級目錄 在可視化工具里就可以看的很明顯了
接下來就是給出我們的posts.show的視圖文件
<html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>Bootstrap Template</title> <!-- 新 Bootstrap 核心 CSS 文件 --> <link rel="stylesheet" rel="external nofollow" > <style> html,body{ width: 100%; height: 100%; } *{ margin: 0; border: 0; } .jumbotron{ margin-top: 10%; } .jumbotron>span{ margin: 10px; } </style> </head> <body> <div class="container"> <div class="row"> <div class="col-xs-12 col-md-12"> <div class="jumbotron"> <h1>Title:{{$post->title}}</h1> <span class="glyphicon glyphicon-eye-open" aria-hidden="true"> {{$post->view_count}} views</span> <p>Content:{{$post->content}}</p> </div> </div> </div> </div> <!-- jQuery文件--> <script src="http://cdn.bootcss.com/jquery/1.11.3/jquery.min.js"></script> <!-- 最新的 Bootstrap 核心 JavaScript 文件 --> <script src="http://cdn.bootcss.com/bootstrap/3.3.5/js/bootstrap.min.js"></script> <script> </script> </body> </html>
【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業(yè)用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。