redis - Sentinel和Cluster的Redis优势
问题描述
我打算创建一个高可用的 Redis 集群。在阅读了许多关于构建 Redis 集群的文章后,我很困惑。那么究竟是什么
- Redis Sentinel Master1 Slave1 Slave2 集群的优势?作为 Redis 多节点 Sharded Cluster 是否更可靠?
- Redis 多节点分片集群的优势?作为 Redis Sentinel Master1 Slave1 Slave2 Cluster 是否更可靠?
对 Redis Sentinel Master1 Slave1 Slave2 Cluster 的进一步问题:
- 当我有 1 个 Master 和两个 Slave 时,流量越来越高,所以这个集群会很小,我怎样才能让集群变大?
Redis 多节点分片集群的其他问题:
- 为什么有这么多在单个实例上但在不同端口上运行集群的演示?这对我来说毫无意义。
- 当我有一个包含 4 个主服务器和 4 个副本的集群时,应用程序或客户端如何确保写入集群?当 Master1 和 Slave1 快死了但我的应用程序总是写入 Master1 的 IP 时,它将不再工作。有哪些解决方案可以很好地实现分片集群,使其可供应用程序使用单个 ip 和端口找到它?保活?代理服务器?
- 当我使用例如 Keepalived 进行 4 个主设置时 - 这不会抵消不同的主吗?
- 此外,我需要了解为什么多节点集群仅适用于在内存可用时需要写入更多数据的解决方案。为什么?对我来说,多主设置听起来很适合可扩展。
- 当集群不处于缓存模式时,分片集群设置不支持多键操作是否正确?
我不确定这两个解决方案是否是唯一的。希望你们能帮助我理解 Redis 的架构。抱歉问了这么多问题。
解决方案
我将尝试回答您的一些问题,但首先让我描述一下 Redis 的不同部署选项。Redis 有三种基本部署:单节点、哨兵和集群。
- 单节点 - 运行 Redis 的单个进程的基本解决方案。它不可扩展且不高度可用。
- Redis Sentinel - 由多个节点组成的部署,其中一个被选为主节点,其余节点为从节点。它增加了高可用性,因为在主故障的情况下,其中一个从属将自动提升为主控。它不可扩展,因为主节点是唯一可以写入数据的节点。您可以将客户端配置为将读取请求定向到从属服务器,这将从主服务器承担一些负载。但是,在这种情况下,从属服务器可能会返回陈旧数据,因为它们异步复制主服务器。
- Redis 集群 - 由至少 6 个节点(3 个主节点和 3 个从节点)组成的部署。数据在主节点之间分片。它是高度可用的,因为在主失败的情况下,他的一个从属将自动提升为主控。它是可扩展的,因为您可以添加更多节点并重新分片数据,以便新节点承担一些负载。
所以回答你的问题:
- Sentinel 相对于 Redis 集群的优势在于:
- 硬件 - 您可以使用三个节点设置完全正常工作的 Sentinel 部署。Redis Cluster 至少需要六个节点。
- 简单——通常更容易维护和配置。
- Redis Cluster 相对于 Sentinel 的优势在于它是可扩展的。
这两个部署之间的决定应基于您的预期负载。如果可以使用单个 Redis 主节点管理写入负载,则可以使用 Sentinel 部署。
如果一个节点无法处理您的预期负载,您必须使用集群部署。
Redis Sentinel 部署不可扩展,因此使集群更大不会提高您的性能。唯一的例外是添加从属可以提高您的读取性能(如果您将读取请求定向到从属)。
在具有多个端口的单个节点上运行的 Redis 集群仅用于开发和演示目的。在生产中它是无用的。
在 Redis 集群部署中,客户端应该可以访问所有节点(并且只有节点 Master1)。这是因为数据在主节点之间分片。如果客户端尝试向 Master1 写入数据,但 Master2 是数据的所有者,则 Master1 将向客户端返回一条 MOVE 消息,引导其向 Master2 发送请求。您不能在所有 Redis 节点前面有一个 HAProxy。
与 5 中的答案相同,在集群部署中,客户端应该直接连接到所有主服务器和从服务器,而不是通过 LB 或 Keepalived。
不确定我是否完全理解您的问题,但 Redis Cluster 是 Redis 唯一可扩展的解决方案。
Redis 集群部署仅在所有键都在同一个节点时才支持多键操作。您可以使用“哈希标签”来强制由同一个主控处理多个密钥。
一些很好的链接可以帮助您更好地理解它:
不同 Redis 部署选项的说明:https ://blog.octo.com/en/what-redis-deployment-do-you-need
Redis Cluster架构详解:https ://blog.usejournal.com/first-step-to-redis-cluster-7712e1c31847
推荐阅读
- ms-access - 如果不是 rs.eof 那么 rs.movefirst 解释
- r - ggplot的自适应设置?
- google-cloud-platform - GCP 负载均衡器指标 API
- shell - AWK - 一次匹配多个模式
- android - 在检索数据后计算值后,有没有办法对 firebaserecyclerview 进行排序?
- javascript - 如何从名称数组中返回所有带有第二个字母“h”的名称?
- javascript - 如何点击没有id的下拉列表
- mongodb - 将有序数组重塑为表格
- android - setColor 小图标通知android
- java - java.lang.UnsupportedOperationException:Robolectric 不支持 API 级别 1