本文共 2055 字,大约阅读时间需要 6 分钟。
按照 Redis 集群所需的依赖进行安装即可。需要注意的是,Redis 5.x 版本不再需要这些依赖。
Redis 3.x 及以上版本的集群采用多主多从架构。集群由多个主机组成,每个主机都有自己的从机。从机的主要职责是同步主机数据,并在主机宕机时顶替主机提供服务。
每个主机的从机负责:
集群搭建至少需要 6 台虚拟机,因为至少需要 3 台主机才能形成一个集群,每个主机至少有一个从机。
在 Redis 配置中,开启 cluster 支持:
cluster-enabled yes
Redis 用于保存集群信息的文件路径为工作目录下的 nodes-9001.conf。
在 bind 配置时,避免配置 127.0.0.1,否则 Redis 会以此 IP 进行连接,导致无法通过外部访问集群。
在 /usr/local/rediss 目录下执行以下命令启动 6 个 Redis 服务:
./startall.sh
查看运行的 Redis 服务:
ps -ef | grep redis
在 /usr/local/redis-4.0.14/src 目录下执行以下命令创建集群:
./redis-trib.rb create --replicas 1 192.168.110.135:9001 192.168.110.135:9002 192.168.110.135:9003 192.168.110.135:9004 192.168.110.135:9005 192.168.110.135:9006
输入 yes 确认创建集群。
集群共有 16384 个槽,索引范围为 0-16383。每个主机负责特定范围的槽,用于负载均衡。
例如:
槽是 Redis 集群用于负载均衡的计量单位,不是存储单位。
使用 Redis 客户端连接集群:
redis-cli -c -p 9001 -h 192.168.110.135
通过 Redis CLI 对集群执行操作:
# 示例:设置用户信息192.168.110.135:9001 set name zhj# 示例:设置性别192.168.110.135:9002 set gender true# 示例:设置年龄192.168.110.135:9003 set age 19
在 Java 项目中配置 Redis 集群连接:
192.168.110.135:9006,192.168.110.135:9007 5
新建一套 Redis 配置,启动新的 Redis 实例,并执行以下命令添加新节点:
./redis-trib.rb add-node 192.168.79.128:9007 192.168.79.128:9006
新添加的主机需要分配槽,确保所有主机的槽负载均衡。执行以下命令重新分片:
./redis-trib.rb reshard 192.168.79.128:9008
将新节点作为从节点添加到集群,执行以下命令:
./redis-trib.rb add-node --slave --master-id ad27f044c31b8c3e0e43a5b1dff080144d9ca85f 192.168.79.128:9008 192.168.79.128:9006
通过以上步骤,可以成功搭建和管理 Redis 集群。
转载地址:http://llwfz.baihongyu.com/