Почему я получаю исключение при использовании Redis кластера Laravel? - PullRequest
0 голосов
/ 31 октября 2019

Я пытаюсь настроить приложение 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=redis

Конфигурация: 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' => [

'client' => env('REDIS_CLIENT', 'phpredis'),

'clusters' => [
    'default' => [
        [
            'host' => env('REDIS_HOST', 'localhost'),
            'password' => env('REDIS_PASSWORD', null),
            'port' => env('REDIS_PORT', 6379),
            'database' => 0,
        ],
    ],
],

],

Ответы [ 2 ]

1 голос
/ 31 октября 2019

Predis был оставлен первоначальным автором пакета и может быть удален из Laravel в будущем выпуске.

Итак, я рекомендую установить php-ext phpredis

.env:

REDIS_CLIENT=phpredis
0 голосов
/ 31 октября 2019

Файл 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 clusters
...