非常教程

Redis参考手册

集合 | Cluster

cluster failover

CLUSTER FAILOVER [FORCE|TAKEOVER]

自3.0.0起可用。

时间复杂度: O(1)

该命令只能发送到 Redis 集群从节点,强制从节点启动其主节点的手动故障转移。

手动故障转移是一种特殊的故障转移,通常在没有实际故障时执行,但我们希望以安全的方式将当前主控与其中一个从属(这是我们发送命令的节点)交换,没有任何数据丢失的窗口。它的工作原理如下:

1. 奴隶告诉主人停止处理来自客户的查询。

2. 主站使用当前复制偏移量答复从站。

3. 从服务器等待复制偏移量与其匹配,以确保它在继续处理之前处理来自主服务器的所有数据。

4. 从站启动故障转移,从大多数主站获得新的配置时期,并广播新配置。

5. 旧的主服务器接收配置更新:取消阻止其客户端并开始使用重定向消息进行回复,以便他们继续与新主服务器聊天。

这样,客户端就会以原子方式从旧主控制器移动到新主控制器,并且只有当变成新主控制器的从控制器才处理来自旧主控制器的所有复制流时。

FORCE 选项:当主站关闭时手动故障切换

命令行为可以通过两个选项进行修改:FORCE TAKEOVER

如果给出 FORCE 选项,则从站不会与主站进行任何握手,但可能无法到达,而是从第4点开始尽快启动故障切换。这对于我们希望在主站点启动手动故障切换时非常有用不再可达。

但是,使用 FORCE,我们仍然需要大多数主设备可用,以授权故障切换并为将成为主设备的从设备生成新的配置时期。

TAKEOVER 选项:无群集共识的手动故障转移

有些情况下,这是不够的,我们希望奴隶故障转移与群集的其他部分没有任何协议。一个真实世界的用例就是在不同的数据中心大量推销奴隶,以便掌握数据中心交换机,而所有主数据中心都被关闭或分区。

TAKEOVER 选项意味着一切 FORCE 意味着,但也不会为了使用故障转移群集的任何授权。取而代之的CLUSTER FAILOVER TAKEOVER是奴隶收到:

1. 生成一个新的configEpoch单方面,只是采取当前最大的纪元可用,并增加它,如果它的本地配置时代还不是最大的。

2. 为其主节点的所有散列槽分配自己,并将新配置传播到每个可以尽快到达的节点,并最终传播到每个其他节点。

请注意,TAKEOVER 违反了 Redis 集群的最后一次故障切换赢得原则,因为从属设备生成的配置时期违反了以下几种方式正常生成配置时期:

1. 不能保证它实际上是更高的配置时期,因为例如我们可以在少数中使用 TAKEOVER 选项,也不会执行任何消息交换来生成新的配置时期。

2. 如果我们生成一个碰巧与另一个实例发生冲突的配置时期,那么最终我们的配置时期或另一个具有相同时期的实例将会使用配置时期冲突解决算法移走。

因此,应小心使用 TAKEOVER 选项。

实施细节和注意事项

CLUSTER FAILOVER,除非指定了 TAKEOVER 选项,否则不会同步执行故障转移,它仅调度手动故障转移,绕过故障检测阶段,因此为了检查是否真的发生了故障转移,应该使用 CLUSTER NODES 或其他方法验证在发送命令一段时间后群集的状态是否发生更改。

返回值

简单字符串回复:OK如果该命令被接受并且将尝试手动故障转移。如果操作无法执行,例如,如果我们正在与已经是主节点的节点交谈,则会出错。

Redis

Redis 是一个开源的使用 ANSI C 语言编写、遵守 BSD 协议、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。 它通常被称为数据结构服务器,因为值( value )可以是 字符串( String ), 哈希(Map),列表(list),集合( sets ) 和 有序集合( sorted sets )等类型。

主页 https://redis.io/
源码 https://github.com/antirez/redis
发布版本 4.0.2

Redis目录

1.集合 | Cluster
2.连接 | Connection
3.Geo
4.Hashes
5.HyperLogLog
6.键 | Keys
7.列表 | Lists
8.Pub/Sub
9.脚本 | Scripting
10.服务器 | Server
11.设定 | Sets
12.排序集 | Sorted Sets
13.字符串 | Strings
14.事务 | Transactions
15.Redis Dump 命令
16.Redis DEL 命令
17.Redis 键(key)
18.Redis 命令
19.Redis 配置
20.Redis 简介
21.Redis RANDOMKEY 命令
22.Redis TTL 命令
23.Redis Pttl 命令
24.Redis PERSIST 命令
25.Redis Move 命令
26.Redis PEXPIREAT 命令
27.Redis Keys 命令
28.Redis Expireat 命令
29.Redis Expire 命令
30.Redis EXISTS 命令
31.Redis Mget 命令
32.Redis Getbit 命令
33.Redis Getset 命令
34.Redis Getrange 命令
35.Redis Get 命令
36.Redis SET 命令
37.Redis 字符串(String)
38.Redis Type 命令
39.Redis Renamenx 命令
40.Redis Rename 命令
41.Redis Incrby 命令
42.Redis Incr 命令
43.Redis Psetex 命令
44.Redis Msetnx 命令
45.Redis Mset 命令
46.Redis Strlen 命令
47.Redis Setrange 命令
48.Redis Setnx 命令
49.Redis Setex 命令
50.Redis Setbit 命令
51.Redis Hincrby 命令
52.Redis Hgetall 命令
53.Redis Hget 命令
54.Redis Hexists 命令
55.Redis Hdel 命令
56.Redis 哈希(Hash)
57.Redis Append 命令
58.Redis Decrby 命令
59.Redis Decr 命令
60.Redis Incrbyfloat 命令
61.Redis Blpop 命令
62.Redis 列表(List)
63.Redis Hvals 命令
64.Redis Hsetnx 命令
65.Redis Hset 命令
66.Redis Hmset 命令
67.Redis Hmget 命令
68.Redis Hlen 命令
69.Redis Hkeys 命令
70.Redis Hincrbyfloat 命令
71.Redis Lrem 命令
72.Redis Lrange 命令
73.Redis Lpushx 命令
74.Redis Lpush 命令
75.Redis Lpop 命令
76.Redis Llen 命令
77.Redis Linsert 命令
78.Redis Lindex 命令
79.Redis Brpoplpush 命令
80.Redis Brpop 命令
81.Redis Sdiff 命令
82.Redis Scard 命令
83.Redis Sadd 命令
84.Redis 集合(Set)
85.Redis Rpushx 命令
86.Redis Rpush 命令
87.Redis Rpoplpush 命令
88.Redis Rpop 命令
89.Redis Ltrim 命令
90.Redis Lset 命令
91.Redis Sunion 命令
92.Redis Srem 命令
93.Redis Srandmember 命令
94.Redis Spop 命令
95.Redis Smove 命令
96.Redis Smembers 命令
97.Redis Sismember 命令
98.Redis Sinterstore 命令
99.Redis Sinter 命令
100.Redis Sdiffstore 命令