A3-1-Linux下 Redis 集群了解

A3-1-Linux Redis 集群了解

参考:http://redisdoc.com/topic/cluster-tutorial.html

本次是通过对官网的学习做一次学习性的笔记

一、集群简介

1、什么是redis集群?

redis集群是一个可以在多个redis节点之间进行数据共享的设施(installation

图片来源:https://www.cnblogs.com/bcde/p/11163362.html

A3-1-Linux下 Redis 集群了解_第1张图片

2redis集群特性

不支持需要同时处理多个键的 Redis 命令, 因为执行这些命令需要在多个 Redis 节点之间移动数据, 并且在高负载的情况下, 这些命令将降低 Redis 集群的性能, 并导致不可预测的行为。

Redis 集群通过分区(partition)来提供一定程度的可用性(availability): 即使集群中有一部分节点失效或者无法进行通讯, 集群也可以继续处理命令请求。

3redis集群优点

将数据自动切分(split)到多个节点的能力。
当集群中的一部分节点失效或者无法进行通讯时, 仍然可以继续处理命令请求的能力。

4、连接

与任意实例连接,即可获得整个集群的数据!通过这个,得做一下读写分离了。

二、集群数据共享

参考:https://www.cnblogs.com/bcde/p/11163362.html

参考:https://www.cnblogs.com/wangfajun/p/12198149.html

Redis 集群使用数据分片(sharding)而非一致性哈希(consistency hashing)来实现: 一个 Redis 集群包含 16384 个哈希槽(hash slot), 数据库中的每个键都属于这 16384 个哈希槽的其中一个, 集群使用公式 CRC16(key) % 16384 来计算键 key 属于哪个槽, 其中 CRC16(key) 语句用于计算键 key CRC16 校验和

这个得在之后的集群操作中熟悉。

三、集群主从复制

为了使得集群在一部分节点下线或者无法与集群的大多数(majority)节点进行通讯的情况下, 仍然可以正常运作, Redis 集群对节点使用了主从复制功能: 集群中的每个节点都有 1 个至 N 个复制品(replica), 其中一个复制品为主节点(master), 而其余的 N-1 个复制品为从节点(slave)。

只要一个槽点存活一个节点服务器,那么集群就不会蹦!

四、Redis 集群的一致性保证(guarantee)风险项,需要考虑解决办法

Redis 集群不保证数据的强一致性(strong consistency): 在特定条件下, Redis 集群可能会丢失已经被执行过的写命令。

1、使用异步复制(asynchronous replication)是 Redis 集群可能会丢失写命令的其中一个原因。 考虑以下这个写命令的例子:

  • 端向主 B 发送一条写命令
  • B 执行写命令,并向客户端返回命令回复
  • B 刚刚执行的写命令复制它的从 B1 B2 B3

如你所 命令的复制工作生在返回命令回复之后, 如果每次理命令求都需要等待复制操作完成的 那么主理命令求的速度将极大地降低 —— 在性能和一致性之做出衡。

2Redis 集群另外一种可能会丢失命令的情况是, 集群出现网络分裂(network partition), 并且一个客户端与至少包括一个主节点在内的少数(minority)实例被孤立。
举个例子, 假设集群包含 A B C A1 B1 C1 六个节点, 其中 A B C 为主节点, A1 B1 C1 分别为三个主节点的从节点, 另外还有一个客户端 Z1
假设集群中发生网络分裂, 那么集群可能会分裂为两方, 大多数(majority)的一方包含节点 A C A1 B1 C1 而少数(minority)的一方则包含节点 B 和客户端 Z1
在网络分裂期间, 主节点 B 仍然会接受 Z1 发送的写命令:

  • 如果网分裂出时间很短, 那么集群会继续正常运行;
  • 但是, 如果网分裂出时间够长 使得大多数一方将从 B1 设置为新的主节点, 并使用 B1 来代替原来的主 B 那么 Z1 发送给主节点 B 的写命令将失。

注意,在网分裂出 Z1 可以向主 B 发送写命令的最大时间是有限制的, 这一时间限制称为节点超时时间(node timeout), Redis 集群的一个重要的配置选项

  • 对于大多数一方来说, 如果一个主点未能在点超时时间定的限内重新系上集群, 那么集群会将个主视为线 并使用从点来代替个主继续工作。
  • 对于少数一方, 如果一个主点未能在点超时时间定的限内重新系上集群, 那么它将停止理写命令, 并向客错误

你可能感兴趣的:(Redis,linux)