Redis与分布式-集群搭建

接上文 Redis与分布式-哨兵模式

1. 集群搭建

搭建简单的redis集群,创建6个配置,开启集群模式,将之前配置过的redis删除,重新复制6份


针对主节点redis 1,redis 2,redis 3都是以上修改内容,只是端口号分别为6001,6002,6003。

然后配置从节点。redis slave 1,redis slave 2,redis slave 3,端口号分别为7001,7002,7003。

配置完启动6个redis

然后输入redis-cli.exe --cluster create --cluster-replicas 1 127.0.0.1:6001 127.0.0.1:6002 127.0.0.1:6003 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003,这里的--cluster-replicas 1指的是每一个节点配置一个从节点

输入yes后等待分配

此时的分配关系为:6001:7003,6002:7001,6003:7002

注:yes之后可能会一直卡顿,我把安全防护和防火墙关闭后没有问题了,如果是校园网有的端口号被封掉也会一直卡着不动。

然后向6001写入数据但是报错,因为写入的地址是15495,而6001分配的插槽范围为0-5460,

此时可通过redis-cli.exe -p 6001 -c启动客户端,若插槽位置不对,会自动转到对应的插槽的redus客户端地址

使用cluster nodes来查看当前所有节点的信息

测试挂掉一个节点,将6001挂掉,查看所有节点信息

然后将6001重新启动查看状态。

若将6001,7003都挂掉

重新启动6001,7003

然后测试使用java连接集群模式下的redis,需要用到JedisCluster对象

c 复制代码
    public static void main(String[] args) {
        //和客户端一样,随便连一个就行,也可以多写几个,构造方法有很多种可以选择
        try(JedisCluster cluster = new JedisCluster(new HostAndPort("127.0.0.1", 6003))){
            System.out.println("集群实例数量:"+cluster.getClusterNodes().size());
            cluster.set("a", "yyds");
            System.out.println(cluster.get("a"));
        }
    }


相关推荐
yyuuuzz2 分钟前
独立站运营的几个技术层面常见问题
大数据·运维·服务器·网络·数据库·aws
IT策士21 分钟前
Redis 从入门到精通:Redis Stream —— 可靠消息队列
数据库·redis·缓存
北风toto21 分钟前
深度拆解:本体与智能体协同生成SQL的底层逻辑与工程实践
数据库·sql·microsoft
倒流时光三十年23 分钟前
PostgreSQL NULLIF 条件表达式函数详解
数据库·sql·postgresql
代码小库35 分钟前
【2026前端转 AI 全栈指南】第 2 章(下):NestJS 项目创建 · MongoDB 配置 · 项目启动与调试
前端·数据库·mongodb
大熊猫侯佩39 分钟前
SwiftData 迁移深度指南:从入门到“填坑”(下集)
数据库·swift·编程语言
大熊猫侯佩44 分钟前
SwiftData 迁移深度指南:从入门到“填坑”(上集)
数据库·swift·编程语言
我星期八休息1 小时前
Linux系统编程—mmap文件映射
java·linux·运维·服务器·数据库·mysql·spring
桌面运维家1 小时前
基于vDisk技术的Vol云桌面技术解析
数据库
放下华子我只抽RuiKe51 小时前
FastAPI 全栈后端(八):部署与运维
运维·数据库·react.js·oracle·数据挖掘·前端框架·fastapi