Redis是一個開源的、高級的鍵值對存儲系統(tǒng),經(jīng)常被用作數(shù)據(jù)結(jié)構(gòu)服務(wù)器,因為其支持字符串、Hash、列表、集合和有序集合等數(shù)據(jù)結(jié)構(gòu)。在Laravel中使用Redis/predis`包(~1.0)。
應(yīng)用的Redis配置位于配置文件config/database.php
。在這個文件中,可以看到包含被應(yīng)用使用的Redis服務(wù)器的redis
數(shù)組:
'redis' => [
'cluster' => false,
'default' => [
'host' => '127.0.0.1',
'port' => 6379,
'database' => 0,
],
],
默認服務(wù)器配置可以滿足開發(fā)需要,然而,你可以基于環(huán)境隨意修改該數(shù)組,只需要給每個Redis服務(wù)器一個名字并指定該Redis服務(wù)器使用的主機和接口。
cluster
選項告訴Laravel Redis 客戶端在多個Redis節(jié)點間執(zhí)行客戶端分片,從而形成節(jié)點池并創(chuàng)建大量有效的RAM。然而,客戶端分片并不處理故障轉(zhuǎn)移,所以,非常適合從另一個主數(shù)據(jù)存儲那里獲取有效的緩存數(shù)據(jù)。
此外,你可以在Redis連接定義中定義options數(shù)組值,從而允許你指定一系列Predis客戶端選項。
如果Redis服務(wù)器要求認證信息,你可以通過添加password
配置項到Redis服務(wù)器配置數(shù)組來提供密碼。
注意:如果你通過PECL安裝PHP的Redis擴展,需要在?
config/app.php
?文件中修改Redis的別名。
你可以通過調(diào)用Redis
門面上的多個方法來與Redis進行交互,該門面支持動態(tài)方法,所以你可以任何Redis命令,該命令將會直接傳遞給Redis,在本例中,我們通過調(diào)用Redis
門面上的get
方法來調(diào)用Redis上的GET命令:
<?php
namespace App\Http\Controllers;
use Redis;use App\Http\Controllers\Controller;
class UserController extends Controller{
/**
* 顯示指定用戶屬性
*
* @param int $id
* @return Response
*/
public function showProfile($id)
{
$user = Redis::get('user:profile:'.$id);
return view('user.profile', ['user' => $user]);
}
}
當(dāng)然,如上所述,可以在Redis
門面上調(diào)用任何Redis命令。Laravel使用魔術(shù)方法將命令傳遞給Redis服務(wù)器,所以只需簡單傳遞參數(shù)和Redis命令如下:
Redis::set('name', 'Taylor');
$values = Redis::lrange('names', 5, 10);
此外還可以使用command
方法傳遞命令到服務(wù)器,該方法接收命令名作為第一個參數(shù),參數(shù)值數(shù)組作為第二個參數(shù):
$values = Redis::command('lrange', ['name', 5, 10]);
**使用多個Redis連接
你可以通過調(diào)用Redis::connection
方法獲取Redis實例:
$redis = Redis::connection();
這將會獲取默認Redis服務(wù)器實例,如果你沒有使用服務(wù)器集群,可以傳遞服務(wù)器名到connection
方法來獲取指定Redis配置中定義的指定服務(wù)器:
$redis = Redis::connection('other');
當(dāng)你需要在一次操作中發(fā)送多個命令到服務(wù)器的時候應(yīng)該使用管道,pipeline
方法接收一個參數(shù):接收Redis實例的閉包。你可以將所有Redis命令發(fā)送到這個Redis實例,然后這些命令會在一次操作中被執(zhí)行:
Redis::pipeline(function ($pipe) {
for ($i = 0; $i < 1000; $i++) {
$pipe->set("key:$i", $i);
}
});
Redis還提供了調(diào)用Redis的publish
和subscribe
命令的接口。這些Redis命令允許你在給定“頻道”監(jiān)聽消息,你可以從另外一個應(yīng)用發(fā)布消息到這個頻道,甚至使用其它編程語言,從而允許你在不同的應(yīng)用/進程之間輕松通信。
首先,讓我們使用subscribe
方法通過Redis在一個頻道上設(shè)置監(jiān)聽器。由于調(diào)用subscribe
方法會開啟一個常駐進程,我們將在Artisan命令中調(diào)用該方法:
<?php
namespace App\Console\Commands;
use Redis;
use Illuminate\Console\Command;
class RedisSubscribe extends Command{
/**
* 控制臺命令名稱
*
* @var string
*/
protected $signature = 'redis:subscribe';
/**
* 控制臺命令描述
*
* @var string
*/
protected $description = 'Subscribe to a Redis channel';
/**
* 執(zhí)行控制臺命令
*
* @return mixed
*/
public function handle()
{
Redis::subscribe(['test-channel'], function($message) {
echo $message;
});
}
}
現(xiàn)在,我們可以使用publish
發(fā)布消息到該頻道:
Route::get('publish', function () {
// 路由邏輯...
Redis::publish('test-channel', json_encode(['foo' => 'bar']));
});
使用psubscribe
方法,你可以訂閱到一個通配符定義的頻道,這在所有相應(yīng)頻道上獲取所有消息時很有用。$channel
名將會作為第二個參數(shù)傳遞給提供的回調(diào)閉包:
Redis::psubscribe(['*'], function($message, $channel) {
echo $message;
});
Redis::psubscribe(['users.*'], function($message, $channel) {
echo $message;
});
更多建議: