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