非常教程

Redis参考手册

集合 | Cluster

cluster forget

CLUSTER FORGET node-id

自3.0.0起可用。

时间复杂度: O(1)

该命令用于从接收命令的 Redis 群集节点的已知节点集合中删除通过节点 ID 指定的节点。换句话说,从接收命令的节点的节点表中删除指定的节点。

因为当给定节点是群集的一部分时,参与群集的所有其他节点都知道它,为了将节点从群集中彻底删除,必须将 CLUSTER FORGET 命令发送到所有其余节点,无论他们是主人或奴隶。

然而,该命令不能简单地从收到该命令的节点的内部节点表中删除该节点,它也实现禁止列表,不允许再次添加同一节点作为处理心跳分组的八卦部分的副作用从其他节点收到。

有关为什么需要禁止列表的详细信息

在下面的例子中,我们将说明为什么该命令不能仅从节点表中移除给定的节点,而是要阻止它再次被重新插入一段时间。

假设我们有四个节点,A,B,C 和 D。为了仅以三个节点集群 A,B,C 结束,我们可以按照以下步骤操作:

1. 重新整理从 D 到节点 A,B,C的 所有散列槽。

2. D 现在是空的,但仍列在 A,B 和 C 的节点表中。

3. 我们联系 A,并发送CLUSTER FORGET D

4. B 向节点 A 发送心跳数据包,其中列出了节点 D.

5. A不再知道节点D(见步骤3),所以它开始与D握手。

6. D 端重新添加到 A 的节点表中。

正如你所看到的那样,删除一个节点是脆弱的,我们需要发送 CLUSTER FORGET 命令给所有的节点,希望在此期间没有处理八卦部分。由于这个问题,该命令为每个条目实施一个带有过期时间的禁止列表。

那么该命令真正的作用是:

1. 指定的节点将从节点表中删除。

2. 删除的节点的节点 ID 被添加到禁止列表中,持续1分钟。

3. 在处理来自其他节点的心跳包中收到的八卦部分时,节点将跳过禁止列表中列出的所有节点 ID。

这样我们有一个60秒的窗口来通知群集中的所有节点我们要删除一个节点。

不允许命令执行的特殊条件

该命令不成功,并在以下情况下返回错误:

1. 节点表中找不到指定的节点标识。

2. 接收命令的节点是从属节点,并且指定的节点ID标识其当前主节点。

2. 节点 ID 标识了我们发送命令的同一个节点。

返回值

简单的字符串回复: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 命令