laravel框架中自己已經存在相應的redis的配置咱們在使用的時候只須要更改配置便可,可是在使用的時候必定要注意命名空間的問題,具體可查看config/app.php下面的aliases數組中具體的路徑php
若是使用的是Homestead虛擬機做爲本地開發環境的話,Homestead已經爲咱們安裝好了Redis並開機啓動,若是是使用Windows開發環境的話,可參考 這篇文章 安裝啓動Redis。html
Redis啓動以後,還須要在Laravel項目根目錄下運行以下命令使用Composer安裝 predis
依賴包:laravel
composer require predis/predis 1.0.*
前面咱們已經提到Redis能夠用做主數據庫,因此Laravel中Redis的配置信息位於 config/database.php
中:redis
'redis' => [
'cluster' => false, 'default' => [ 'host' => '127.0.0.1', 'port' => 6379, 'database' => 0, ], ],
其中 cluster
選項表示是否在多個Redis節點間進行分片,這裏咱們本地測試只有一個節點故將其設置爲 false
。數據庫
default
選項表示默認Redis主機鏈接,這裏Redis和Web服務器共用一臺主機,因此 host
爲127.0.0.1,Redis默認端口是6379。數組
此外, default
選項還支持更多鏈接參數(若是須要的話):緩存
參數 | 意義 | 默認值 |
---|---|---|
host | 服務器IP地址/主機名稱 | 127.0.0.1 |
port | Redis服務器監聽的端口號 | 6379 |
password | 若是服務器須要認證密碼 | 不使用密碼 |
database | 鏈接時選擇的數據庫索引ruby |
沒有設置索引 |
timeout | 鏈接到Redis服務器超時時間 | 5秒 |
read_write_timeout | 經過網絡鏈接進行讀寫操做的超時時間 | 系統默認(不限制超時時間的話設置爲-1)服務器 |
另外Redis若是是做爲緩存工具,還須要在 config/cache.php
配置 redis
選項:網絡
'redis' => [
'driver' => 'redis', 'connection' => 'default', ],
這裏的 connection
對應 config/database
中 redis
的默認主機 default
配置。
完成上述配置以後咱們就能夠在應用代碼中使用Redis進行數據存取了。
因爲Laravel默認已經將Redis門面添加到 config/app.php
的 aliases
數組中,因此在代碼中能夠直接使用該門面進行Redis操做。咱們能夠在Redis門面上以靜態方法的方式調用Redis客戶端提供的任何命令( Redis命令大全 ),而後Laravel使用魔術方法將命令傳遞給Redis服務器並返回獲取的結果。
下面咱們來看最簡單的讀取操做:
$key = 'user:name:6'; $user = User::find(6); if($user){ //將用戶名存儲到Redis中 Redis::set($key,$user->name); } //判斷指定鍵是否存在 if(Redis::exists($key)){ //根據鍵名獲取鍵值 dd(Redis::get($key)); }
以上是簡單的字符串存取,下面咱們看一個更復雜的例子,將獲取到的數據存放到集合中:
$key = 'posts:title'; $posts = Post::all(); foreach ($posts as $post) { //將文章標題存放到集合中 Redis::sadd($key,$post->title); } //獲取集合元素總數(若是指定鍵不存在返回0) $nums = Redis::scard($key); if($nums>0){ //從指定集合中隨機獲取三個標題 $post_titles = Redis::srandmember($key,3); dd($post_titles); }
注:集合與列表的區別在於集合中是不容許重複元素出現的,沒錯,這就是數學中集合的互異性的體現;有序集合與集合的區別在於有序集合是有序的,這則是數學集合無序性的體現。
注:https://www.cnblogs.com/mzli/p/5748608.html