请教 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."
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 11
Epona
4年前 评论

@Epona 多谢。

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

4年前 评论
Epona

@wangxp :joy:

4年前 评论

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

MOVED 5878 172.25.0.7:6379

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

   'redis' => [
        'client' => 'predis',

//        'default' => [
//            'host' => env('REDIS_HOST', '127.0.0.1'),
//            'password' => env('REDIS_PASSWORD', null),
//            'port' => env('REDIS_PORT', 6379),
//            'database' => env('REDIS_DB', 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),
//        ],
        'options' => [
            'cluster' => 'redis',
        ],
        'clusters' => [
            'default' => [
                [
                    'host' => 'redis1',
                    'password' => null,
                    'port' => 6379,
                    'database' => 0,
                ],
                [
                    'host' => 'redis2',
                    'password' => null,
                    'port' => 6379,
                    'database' => 0,
                ],
                [
                    'host' => 'redis3',
                    'password' => null,
                    'port' => 6379,
                    'database' => 0,
                ],
                [
                    'host' => 'redis4',
                    'password' => null,
                    'port' => 6379,
                    'database' => 0,
                ],
                [
                    'host' => 'redis5',
                    'password' => null,
                    'port' => 6379,
                    'database' => 0,
                ],
                [
                    'host' => 'redis6',
                    'password' => null,
                    'port' => 6379,
                    'database' => 0,
                ],
            ]
        ],

    ],
4年前 评论
xiaoyu_xu (作者) 4年前
wangxp (楼主) 4年前
WhiteDragon 4年前

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

4年前 评论

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

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

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

file

1年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!