博客
关于我
Redis集群搭建
阅读量:467 次
发布时间:2019-03-06

本文共 2055 字,大约阅读时间需要 6 分钟。

Redis 集群搭建指南

1. 安装依赖

按照 Redis 集群所需的依赖进行安装即可。需要注意的是,Redis 5.x 版本不再需要这些依赖。


2. 集群介绍

Redis 3.x 及以上版本的集群采用多主多从架构。集群由多个主机组成,每个主机都有自己的从机。从机的主要职责是同步主机数据,并在主机宕机时顶替主机提供服务。

每个主机的从机负责:

  • 同步主机数据
  • 在主机宕机时替换主机提供服务

  • 3. 集群搭建

    集群搭建至少需要 6 台虚拟机,因为至少需要 3 台主机才能形成一个集群,每个主机至少有一个从机。


    3.1 搭建配置

    在 Redis 配置中,开启 cluster 支持:

    cluster-enabled yes

    Redis 用于保存集群信息的文件路径为工作目录下的 nodes-9001.conf

    在 bind 配置时,避免配置 127.0.0.1,否则 Redis 会以此 IP 进行连接,导致无法通过外部访问集群。


    3.2 启动 Redis

    /usr/local/rediss 目录下执行以下命令启动 6 个 Redis 服务:

    ./startall.sh

    查看运行的 Redis 服务:

    ps -ef | grep redis

    3.3 创建集群

    /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 确认创建集群。


    4. 槽

    集群共有 16384 个槽,索引范围为 0-16383。每个主机负责特定范围的槽,用于负载均衡。

    例如:

    • 主机 1 负责槽 0-5460
    • 主机 2 负责槽 5461-10922
    • 主机 3 负责槽 10923-16383

    槽是 Redis 集群用于负载均衡的计量单位,不是存储单位。


    5. 连接集群

    使用 Redis 客户端连接集群:

    redis-cli -c -p 9001 -h 192.168.110.135

    6. 集群操作

    通过 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

    7. Java 连接集群

    在 Java 项目中配置 Redis 集群连接:

    192.168.110.135:9006,192.168.110.135:9007
    5

    8. 添加主节点

    8.1 添加新节点

    新建一套 Redis 配置,启动新的 Redis 实例,并执行以下命令添加新节点:

    ./redis-trib.rb add-node 192.168.79.128:9007 192.168.79.128:9006

    8.2 重新分片

    新添加的主机需要分配槽,确保所有主机的槽负载均衡。执行以下命令重新分片:

    ./redis-trib.rb reshard 192.168.79.128:9008

    9. 添加从节点

    9.1 添加新节点

    将新节点作为从节点添加到集群,执行以下命令:

    ./redis-trib.rb add-node --slave --master-id ad27f044c31b8c3e0e43a5b1dff080144d9ca85f 192.168.79.128:9008 192.168.79.128:9006

    通过以上步骤,可以成功搭建和管理 Redis 集群。

    转载地址:http://llwfz.baihongyu.com/

    你可能感兴趣的文章
    pandas 版本兼容特定的蟒蛇和NumPy配置吗?
    查看>>
    pandas 生成excel多级表头
    查看>>
    Pandas 的 DataFrame 详解-ChatGPT4o作答
    查看>>
    pandas 读取excel数据,以字典形式输出
    查看>>
    Pandas 读取具有浮点值的 csv 文件会导致奇怪的舍入和小数位数
    查看>>
    pandas 适用,但仅适用于满足条件的行
    查看>>
    pandas 重新采样到每月的特定工作日
    查看>>
    pandas :如何删除以NaN为列名的多个列?
    查看>>
    pandas :我如何对堆叠的条形图进行分组?
    查看>>
    pandas :按移位分组和累加和(GroupBy Shift And Cumulative Sum)
    查看>>
    pandas :检测一个DF和另一个DF之间缺失的列
    查看>>
    Pandas-从具有嵌套列表列表的现有列创建动态列时出错
    查看>>
    Pandas-通过对列和索引的值求和来合并两个数据框
    查看>>
    pandas.columns、get_dummies等用法
    查看>>
    pandas.DataFrame.copy(deep=True) 实际上并不创建深拷贝
    查看>>
    pandas.read_csv()的详解-ChatGPT4o作答
    查看>>
    PANDAS.READ_EXCEL()输出‘;溢出错误:日期值超出范围‘;而不存在日期列
    查看>>
    pandas100个骚操作:再见 for 循环!速度提升315倍!
    查看>>
    Pandas:如何根据其他列值的条件对列进行求和?
    查看>>
    Pandas:对给定列求和 DataFrame 行
    查看>>