我正在尝试配置我的Laravel配置以接受多个redis节点,但我得到了一个例外:
exception: "Predis\Response\ServerException"
file: "/home/vagrant/code/gryphon-laravel/vendor/predis/predis/src/Client.php"
line: 370
message: "MOVED 9576 10.225.25.33:6380"生成异常的代码:
$user = Redis::get('anything');
.env
REDIS_CLUSTER=redis
REDIS_CLIENT=predis
CACHE_DRIVER=redis
QUEUE_DRIVER=redis
BROADCAST_DRIVER=redisConfig: database.php
[...]
'redis' => [
'cluster' => true,
'client' => env('REDIS_CLIENT', 'predis'),
'clusters' => [
'first' => [
[
'host' => env('REDIS_HOST', 'localhost'),
'port' => env('REDIS_PORT', 6379),
'database' => 0,
]
],
'second'=> [
[
'host' => env('REDIS_HOST_2', 'localhost'),
'port' => env('REDIS_PORT_2', 6379),
'database' => 0,
]
],
'third'=> [
[
'host' => env('REDIS_HOST_3', 'localhost'),
'port' => env('REDIS_PORT_3', 6379),
'database' => 0,
],
]
],
'options' => [
'cluster' => env('REDIS_CLUSTER', 'predis'),
'prefix' => Str::slug(env('APP_NAME', 'laravel'), '_').'_database_',
'parameters' => [
'password' => env('REDIS_PASSWORD', null),
],
],
'default' => [
'host' => env('REDIS_HOST', '127.0.0.1'),
'port' => env('REDIS_PORT', 6379),
'database' => env('REDIS_DB', 0),
],
'cache' => [
'host' => env('REDIS_HOST', '127.0.0.1'),
'port' => env('REDIS_PORT', 6379),
'database' => env('REDIS_CACHE_DB', 1),
]
],
[...]我搜了又搜,却什么也没找到.
这边的文档有点模糊:
如果应用程序正在使用Redis服务器集群,则应在Redis配置的群集键中定义这些群集: 'redis‘=> [’=> env‘(’REDIS_CLIENT‘,'phpredis'),’=>‘默认’=> [‘主机’=> env(‘REDIS_ =>’,'localhost'),‘=> env’(‘REDIS_密码’,null),‘端口’=> env('REDIS_PORT',6379),‘数据库’=> 0,], ],
发布于 2019-10-31 11:01:52
Predis已经被软件包的原始作者所抛弃,并可能在以后的版本中从Laravel中删除。
因此,我建议安装php-ext phpredis。
.env:
REDIS_CLIENT=phpredis发布于 2019-10-31 10:44:28
文件config/database.php
$redisConnStr = env('REDIS_CONNECTION', '127.0.0.1:6379');
$redis = [
'client' => 'predis',
];
$redisConnections = explode(',', $redisConnStr);
if (count($redisConnections) === 1) {
$params = explode(':', $redisConnections[0]);
$redis = array_merge(
$redis,
[
'cluster' => env('REDIS_CLUSTER', false),
'default' => [
'host' => $params[0] ?? '127.0.0.1',
'password' => env('REDIS_PASSWORD', null),
'port' => (int)($params[1] ?? 6379),
'database' => env('REDIS_DATABASE', 0),
]
]
);
}
else {
$redisCacheCluster = [];
foreach ($redisConnections as $conn){
$params = explode(':', $conn);
$redisCacheCluster[] = [
'host' => $params[0] ?? '127.0.0.1',
'password' => env('REDIS_PASSWORD', null),
'port' => (int)($params[1] ?? 6379),
];
}
$redis = array_merge(
$redis,
[
'options' => ['cluster' => 'redis'],
'clusters' => [
'default' => $redisCacheCluster,
]
]
);
}
'redis' => $redis,文件config/cache.php
'redis' => [
'driver' => 'redis',
'connection' => 'default',
],文件.env
REDIS_CONNECTION=127.0.0.1:6379, //all ips redis clustershttps://stackoverflow.com/questions/58641301
复制相似问题