0

0

Linux Redis 集群搭建与调优

舞夢輝影

舞夢輝影

发布时间:2026-02-18 14:04:03

|

512人浏览过

|

来源于php中文网

原创

redis集群初始化报“node is not empty”需先flushall并清理rdb/aof文件;slot分配不均用reshard均衡;从节点failover失败需检查cluster-require-full-coverage和cluster-replica-no-failover配置。

linux redis 集群搭建与调优

redis-cli --cluster create 报错 Node is not empty

集群初始化时提示 Node is not empty,说明目标 Redis 实例的 db0 里已有数据或 AOF/RDB 文件残留,redis-cli --cluster create 默认拒绝覆盖。

  • 先连上该节点执行 FLUSHALL,再删掉本地 dump.rdbappendonly.aof(路径看 config get dirconfig get dbfilename
  • 确认 redis.confcluster-enabled yes 已开启,且 portbindprotected-mode no 都配对——尤其 protected-mode no 在集群通信中不设会直接被拒绝握手
  • 别用 redis-server redis.conf & 启动后立刻跑 --cluster create:Redis 启动有延迟,建议加 sleep 2 或用 redis-cli ping 轮询确认服务就绪

集群 slot 分配不均导致写入卡顿

redis-cli --cluster check 发现某些 master 的 slot 数远高于其他节点,写请求集中打到少数实例,CPU 或内存飙升。

  • 分配 slot 时别手敲 16384 个数,用 --cluster create 自动均分;若已部署,用 redis-cli --cluster reshard 迁移,指定源节点 hash slot 范围而非单个 slot
  • reshard 过程中客户端可能收到 MOVEDASK 重定向,要求 client 支持集群协议(如 Jedis 3.0+、redis-py 4.0+),旧版 client 会报 ConnectionError
  • 迁移大 key(如 >1MB 的 hash)会阻塞源节点,建议提前用 redis-cli --bigkeys 扫描,拆分或剔除

从节点无法自动故障转移(failover)

主节点宕机后,集群没升任从节点,状态卡在 fail? ,应用持续报 CLUSTERDOWN

《高性能Linux服务器构建实战-运维监控、性能调优与集群应用》
《高性能Linux服务器构建实战-运维监控、性能调优与集群应用》

《高性能Linux服务器构建实战-运维监控、性能调优与集群应用》

下载
  • 检查从节点的 cluster-require-full-coverage no 是否设置——默认是 yes,只要有一个 slot 不可用就拒绝服务;设为 no 才允许部分 slot 下线时继续响应
  • 确认从节点的 cluster-replica-no-failoverno(旧版叫 cluster-slave-validity-factor),否则它会主动放弃参选
  • 网络延迟超过 cluster-node-timeout(默认 15000ms)会导致误判,生产环境建议调低到 5000–8000ms,并确保所有节点间 ping 延迟

使用 redis-py 连集群总连错节点或超时

Python 程序用 RedisCluster 初始化后,读写随机失败,日志频繁出现 ConnectionError: Error 111 connecting to xxx:7001

  • 别传单个节点地址,必须传全部 master 节点(至少一个):构造时用 startup_nodes=[{"host": "10.0.1.10", "port": "7001"}, ...]
  • 关闭 skip_full_coverage_check=True,否则集群部分不可用时 client 直接抛异常而不是降级访问
  • 连接池参数要显式设大些:max_connections=100socket_timeout=3,避免短连接风暴压垮节点

集群拓扑变更(如增删节点、reshard)后,client 缓存的 slot 映射不会自动刷新,得靠定期 CLUSTER SLOTS 轮询或等下次 MOVED 触发更新——这个延迟期就是最易出错的时间窗口。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

481

2023.11.27

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

371

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.10.25

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

994

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

661

2023.11.14

mongodb和redis哪个读取速度快
mongodb和redis哪个读取速度快

redis 的读取速度比 mongodb 更快。原因包括:1. redis 使用简单的键值存储,而 mongodb 存储 json 格式的数据,需要解析和反序列化。2. redis 使用哈希表快速查找数据,而 mongodb 使用 b-tree 索引。因此,redis 在需要高性能读取操作的应用程序中是一个更好的选择。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

496

2024.04.02

redis怎么做缓存服务器
redis怎么做缓存服务器

redis 作为缓存服务器的答案:redis 是一款开源、高性能、分布式的键值存储,可作为缓存服务器使用。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

406

2024.04.07

redis怎么解决数据一致性
redis怎么解决数据一致性

redis 提供了两种一致性模型,以维护副本数据一致性:强一致性 (sync) 确保写操作仅在复制到所有从节点后才完成;最终一致性 (async) 则在主节点上写操作后认为已完成,牺牲一致性换取性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

404

2024.04.07

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

561

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.3万人学习

Git 教程
Git 教程

共21课时 | 3.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号