当前位置: 首页 > article >正文

Redis 组网方式入门

文章目录

  • 一、组网方式
    • 1. 单实例模式
      • 描述
      • 优点
      • 缺点
      • 适用场景
    • 2. 主从复制模式(Master-Slave Replication)
      • 描述
      • 优点
      • 缺点
      • 适用场景
      • 基于docker的redis主从复制
        • 1. 配置主节点
        • 2. 配置从节点
        • 3. 查看节点状态
        • 4. 验证主从数据同步
        • 5. 查看同步进度
    • 3. 哨兵模式(Sentinel)
      • 描述
      • 优点
      • 缺点
      • 适用场景
    • 4. 集群模式(Cluster)
      • 描述
      • 优点
      • 缺点
      • 适用场景
    • 5. 分片模式
      • 5.1 代理分片模式(Proxy-based Sharding)
        • 描述
        • 优点
        • 缺点
      • 5.2 客户端分片模式(Client-side Sharding)
        • 描述
        • 优点
        • 缺点
  • 二、总结

Redis 是一个开源的、基于键值对的内存数据存储系统,广泛应用于缓存、消息队列、数据库等多种场景。随着业务需求的不断增长,单一的 Redis 实例往往无法满足高可用性和高性能的要求。因此,Redis 提供了多种组网方式来应对不同的应用场景。本文将详细介绍 Redis 的几种主要组网方式及其优缺点。
在这里插入图片描述

一、组网方式

1. 单实例模式

描述

这是最基本的部署方式,Redis 服务运行在一个单独的服务器上,没有冗余机制。

优点

简单易用:配置和管理都非常简单,适合小型应用或测试环境。
资源利用率高:不需要额外的服务器资源,成本较低。

缺点

单点故障:一旦该实例发生故障,整个服务将不可用,存在较高的风险。
性能瓶颈:所有请求都集中在同一个实例上,容易成为性能瓶颈。

适用场景

小型应用或测试环境
对高可用性和性能要求不高的场景

2. 主从复制模式(Master-Slave Replication)

描述

一个主节点(Master)可以有多个从节点(Slave),主节点负责写操作,从节点负责读操作。数据从主节点异步复制到从节点。

优点

提高读取性能:通过读写分离,从节点可以分担主节点的读取压力。
数据冗余:支持数据备份,提高了数据的安全性。
灵活扩展:可以轻松添加更多的从节点来提升读取性能。

缺点

单点故障:主节点故障时需要手动切换,存在单点故障风险。
数据一致性:由于数据复制是异步的,可能会导致主从节点之间的数据不一致。

适用场景

读多写少的应用场景
需要数据备份和读写分离的场景

基于docker的redis主从复制

1. 配置主节点
  • 编辑主节点配置文件
# 绑定 IP 地址,允许远程连接
bind 0.0.0.0

# 配置端口号
port 6379

# 设置密码(可选)
requirepass 123456

# 开启 AOF 持久化(可选)
appendonly yes

# 设置日志级别
loglevel notice

# 设置日志文件路径
logfile /var/log/redis/redis.log
  • 启动主节点
docker run -d -P \
--name redis7-master \
-p 6379:6379 \
-p 16379:16379 \
-v /work/docker/redis/data/master_6379:/data \
-v /work/docker/redis/data/master_6379/log:/var/log/redis \
-v /work/docker/redis/conf/master_6379.conf:/etc/redis/redis.conf \
redis:latest \
redis-server /etc/redis/redis.conf
  • 查看主节点IP
$ docker inspect redis7-master | grep IPAdd
            "SecondaryIPAddresses": null,
            "IPAddress": "172.17.0.2",
                    "IPAddress": "172.17.0.2",

如果是生产环境,一般不使用docker,直接部署到物理机,IP地址也是已知确定的;本人使用docker部署,此处查看主节点IP,方便后续部署从节点时使用该IP。

2. 配置从节点
  • 编辑主节点配置文件
# 绑定 IP 地址,允许远程连接
bind 0.0.0.0

# 配置端口号
port 6380

# 设置密码(如果主节点设置了密码)
masterauth 123456

# 设置密码(可选)
requirepass 12345678

# 开启 AOF 持久化(可选)
appendonly yes

# 设置日志级别
loglevel notice

# 设置日志文件路径
logfile /var/log/redis/redis.log

# 指定主节点的地址和端口
replicaof 172.17.0.2 6379

replicaof 命令使用的IP即是主节点的IP。

  • 启动从节点
docker run -d -P \
--name redis7-slave \
-p 6380:6380 \
-p 16380:16380 \
-v /work/docker/redis/data/slave_6380:/data \
-v /work/docker/redis/data/slave_6380/log:/var/log/redis \
-v /work/docker/redis/conf/slave_6380.conf:/etc/redis/redis.conf \
redis:latest \
redis-server /etc/redis/redis.conf
3. 查看节点状态
  • 检查主节点状态
docker exec -it redis7-master bash
redis-cli -a 123456
info replication
# Replication
role:master
connected_slaves:1
slave0:ip=172.17.0.4,port=6380,state=online,offset=43,lag=0
……

应该能看到 role:masterconnected_slaves:1,表示有一个从节点连接成功。

  • 检查从节点状态
docker exec -it redis7-slave bash
redis-cli -p 6380 -a 12345678
> info replication
# Replication
role:slave
master_host:172.17.0.2
master_port:6379
master_link_status:up
master_last_io_seconds_ago:4
master_sync_in_progress:0
……

应该能看到 role:slavemaster_host:<master_ip>master_link_status:up,表示从节点已成功连接到主节点。

在从节点执行slaveof <master_ip> <master_port>slaveof no one也可以快速搭建和解散主从网络。

4. 验证主从数据同步
  • 在主节点上写入数据
set k1 hello
  • 在从节点上读取数据
get k1

如果返回 hello,说明数据同步成功。

5. 查看同步进度
  • 在主节点执行info replication命令
# slave0后面显示从节点的IP、端口、状态、偏移量和延迟
slave0:ip=172.17.0.4,port=6380,state=online,offset=3179,lag=1
master_repl_offset:3179 # 表示主节点的复制偏移量
  • 在从节点执行info replication命令
slave_repl_offset:3501 # 表示从节点的复制偏移量
master_repl_offset:3501 # 表示主节点的复制偏移量
  • 在主节点或任意从节点执行MONITOR命令
    该命令将显示所有接收到的命令,包括主从同步相关的命令。

  • 在主节点执行CLIENT LIST命令
    在这里插入图片描述
    flags=S:表示这是一个从节点连接。

3. 哨兵模式(Sentinel)

描述

哨兵模式在主从复制模式的基础上增加了哨兵节点,哨兵节点负责监控主从节点的健康状态,并在主节点故障时自动进行故障转移。

优点

自动化故障恢复:哨兵节点可以自动检测并恢复主节点故障,提高了系统的可用性。
高可用性:通过自动故障转移,减少了服务中断时间。

缺点

配置复杂:需要配置多个哨兵节点和主从节点,管理较为复杂。
资源消耗:哨兵节点会占用一定的系统资源。

适用场景

高可用性要求较高的生产环境
需要自动故障恢复的场景

4. 集群模式(Cluster)

描述

Redis 集群模式支持数据分片(Sharding),每个节点负责一部分数据,通过哈希槽(Hash Slot)机制实现数据的分布式存储。

优点

水平扩展:支持水平扩展,提高了系统的存储容量和处理能力。
高可用性:通过数据分片和副本机制,提高了系统的可用性。
负载均衡:请求均匀分布在多个节点上,避免了单点性能瓶颈。

缺点

配置复杂:需要配置多个节点和哈希槽,管理较为复杂。
客户端要求:客户端需要支持集群模式,增加了客户端的复杂度。

适用场景

大规模分布式系统
需要高可用性和高性能的场景

5. 分片模式

5.1 代理分片模式(Proxy-based Sharding)

描述

通过代理层实现数据分片,客户端请求先经过代理层,由代理层决定将请求路由到哪个Redis实例。

优点

客户端无需关心数据分片逻辑,易于实现读写分离。

缺点

代理层可能成为性能瓶颈,增加了系统复杂度。

5.2 客户端分片模式(Client-side Sharding)

描述

客户端直接负责数据分片逻辑,将请求直接发送到相应的Redis实例。

优点

减少了代理层的开销,提高了性能。

缺点

客户端实现复杂,数据分片逻辑需要在客户端维护,增加了客户端的负担。

二、总结

Redis 提供了多种组网方式,每种方式都有其适用的场景和优缺点。选择合适的组网方式需要根据具体的业务需求、性能要求和运维能力来决定。例如,对于简单的应用,单实例模式或主从复制模式可能就足够了;而对于高可用性和高性能要求的场景,集群模式或哨兵模式可能是更好的选择。
希望本文能够帮助到你。


http://www.kler.cn/a/380151.html

相关文章:

  • PostgreSQL (八) 创建分区
  • Chrome 130 版本开发者工具(DevTools)更新内容
  • Chromium Mojo(IPC)进程通信演示 c++(1)
  • python在word的页脚插入页码
  • 我们来学mysql -- 同时使用 AND 和 OR 查询错误(填坑篇)
  • Java环境下配置环境(jar包)并连接mysql数据库
  • Leetcode 3343. Count Number of Balanced Permutations
  • HTMLCSS:呈现的3D树之美
  • mysql笔记-索引
  • vue经典前端面试题
  • Vue 自定义icon组件封装SVG图标
  • 数据结构----二叉树
  • 请用python写一段训练模型【InsCode AI 创作助手】
  • #Prompt | AI | LLM # 人类如何写出LLM理解的Prompt
  • 使用JavaScript实现新窗口打开并设置sessionStorage的简单指南
  • 批发订货系统的设计、开发及源码实现(PHP + MySQL)
  • java项目之校园资料分享平台(springboot)
  • OpenGL入门005——使用Shader类管理着色器
  • js.轮转数组和旋转链表
  • linux shell脚本学习(1):shell脚本基本概念与操作
  • 递归的相关知识(Java)全面版
  • JavaEE初阶---网络原理之TCP篇(二)
  • [VUE]框架网页开发1 本地开发环境安装
  • 北斗有源终端|智能5G单北斗终端|单兵|单北斗|手持机
  • LINUX_Ubuntu终端安装tools的命令
  • 详解Rust标准库:HashMap