Redis从3.0.7升级到5

Jir*_*ene 5 redis node-redis redis-sentinel redis-cluster

我有许多运行3.0.7的Sentinel和群集服务器,需要升级到5。我无法承受停机时间。有人可以建议我该怎么做吗?一些数据库太大,以至于最好的解决方案是服务器无法分配新实例/第二实例,这是在同一台服务器上使用新的Redis 5并将其设置为3.0.7的从属。

1)我可以直接从3.2转到5,还是需要先跳到4?

2)从此处读取内容,当从3.3升级到4时,需要大量重新启动。是否有避免停机的方法?如何重建原始群集数据?备份还原?

欢迎任何建议。

小智 1

您可以更改redis 5.0集群总线协议,使其兼容3.0.7。

Redis 5.0的集群总线协议为1,而redis 3.0.7的集群总线协议为0。

您必须注意以下两个差异:

  1. 集群总线协议 1 支持模块消息,而协议 0 不支持。
  2. 集群总线协议 1 的 ping 消息有一个额外的“cport”字段。