请教 Redis cluster 配置使用问题

问题描述:在 laravel 5.8 使用 cache + redis cluster 一直去连接本地 redis 服务器。

版本信息:

"require": {
        "php": "^7.1.3",
        "dingo/api": "^2.2",
        "fideloper/proxy": "^4.0",
        "jenssegers/mongodb": "^3.5",
        "laravel/framework": "^5.8",
        "laravel/tinker": "^1.0",
        "predis/predis": "^1.1",
        "ext-json": "*"
    },

.env 中

    CACHE_DRIVER=redis

cache.php 配置:

    'redis' => [
            'driver' => 'redis',
//            'connection' => 'cache',
            'connection' => 'default',
        ],

database.php 配置:

    'redis' => [
       // 'cluster' => 'true',
        'client' => env('REDIS_CLIENT', 'predis'),

        'options' => [
            'cluster' => env('REDIS_CLUSTER', 'redis'),
//            'parameters' => ['password' => env('REDIS_PASSWORD', null)],
        ],

        'clusters' => [
            'default' => [
                [
                    'host' => env('REDIS_HOST_A'),
                    'password' => env('REDIS_PASSWORD_A'),
                    'port' => env('REDIS_PORT_A', 6379),
                    'database' => env('REDIS_DB_A', 0),
                ],
                [
                    'host' => env('REDIS_HOST_B'),
                    'password' => env('REDIS_PASSWORD_B'),
                    'port' => env('REDIS_PORT_B', 6379),
                    'database' => env('REDIS_DB_B', 0),
                ],
                [
                    'host' => env('REDIS_HOST_C'),
                    'password' => env('REDIS_PASSWORD_C'),
                    'port' => env('REDIS_PORT_C', 6379),
                    'database' => env('REDIS_DB_C', 0),
                ],
                [
                    'host' => env('REDIS_HOST_D'),
                    'password' => env('REDIS_PASSWORD_D'),
                    'port' => env('REDIS_PORT_D', 6379),
                    'database' => env('REDIS_DB_D', 0),
                ],
                [
                    'host' => env('REDIS_HOST_E'),
                    'password' => env('REDIS_PASSWORD_E'),
                    'port' => env('REDIS_PORT_E', 6379),
                    'database' => env('REDIS_DB_E', 0),
                ],
                [
                    'host' => env('REDIS_HOST_F'),
                    'password' => env('REDIS_PASSWORD_F'),
                    'port' => env('REDIS_PORT_F', 6379),
                    'database' => env('REDIS_DB_F', 0),
                ],
            ],
        ],
//        'cache'   => [
//            'host'     => env('REDIS_HOST', '127.0.0.1'),
//            'password' => env('REDIS_PASSWORD', null),
//            'port'     => env('REDIS_PORT', 6379),
//            'database' => env('REDIS_CACHE_DB', 1),
//        ],

    ],

请帮忙看看哪里配置的不对?clusters 中的 redis 无密码,配置为 null 。一直在连接本地 redis 服务器。

请教 Redis cluster 配置使用问题
打印了下

    "tcp://127.0.0.1:6379"

因为本地 redis 有密码,所以一直报

message: "NOAUTH Authentication required."
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 11
Epona
5年前 评论

@Epona 多谢。

莫名其妙自己就好了,代码无修改。是什么问题也不清楚,很尴尬!

5年前 评论
Epona
5年前 评论

我配置了 redis cluster 集群在 cli 中各个主节点都能正常插入,然后在 laravel 中有的主节点就报

MOVED 5878 172.25.0.7:6379

类似这种错误,有的主节点能够正常插入。楼主有遇到过吗?还有我配置 redis cluster 只需要修改 database.php 就可以了吗?下面是我代码。这个问题很无语啊。

代码已被折叠,点此展开
5年前 评论
xiaoyu_xu (作者) 5年前
wangxp (楼主) 5年前
WhiteDragon 5年前

cluster 是无法修改 db 的,热点 DB 有时候会被 GC, 你要不考虑下哨兵模式

5年前 评论

请问最后怎么解决的,大佬写的是无缘无故就好了?

5年前 评论
  • 如果你没有安装 horizon + 设定密码的话,按照官方文档配置,没有问题。
  • 如果你没有安装 horizon,但设定了集群密码的话,首先全部 Redis 节点的 requirepass 和 masterauth 都需要设定相同的密码,其次在 config/database.php 的 ‘clusters’ => [],下必须把全部节点都设定好。
  • 如果你安装了 horizon 又设定了集群密码,那么首先要参照 2 完成配置,其次,需要为 horizon 单独配置一个 Redis 实例,配置为 horizon,再在 config/horizon.php 中的 ‘use’ => ‘horizon’
4年前 评论

想问下该栏 redis 集群操作,用的 predis,他的删除 key 没有问题?为什么我这边使用说不支持 del。

file

2年前 评论