当前位置: 首页> 房产> 政策 > Redis到底是AP还是CP?

Redis到底是AP还是CP?

时间:2025/7/11 2:32:32来源:https://blog.csdn.net/asdfgh0308/article/details/139374013 浏览次数:0次

这个问题差评,没问清楚。当然,网上一搜,各种各样的狗屁答案都有,有时候是AP的,有时候是CP的,薛定谔的Redis。

好的,那应该怎么问呢?
Q1.Redis Cluster集群是AP还是CP?

A1:Redis Cluster既不是AP,也不是CP,而是AC,也就是没有分区容错性。

啥叫分区容错性,就是有多个备份,掉了一个节点,还可以继续玩。集群行吗?我们都知道它集群是一致性HASH,一个key只存在一个节点上,那么还有啥容错性?所以它没有P。至于AC,都有,思考一下。

Q2.Redis主备是AP还是CP?

A2:Redis主备模式,有多个备份,OK,P有了。但主备采用异步复制,复制不影响主的使用,存在不一致的状态,在复制过程中,主挂了,将出现主备不一致,因此是非C的。所以主备是AP。

Q3.Redis主备加集群是AP还是CP?

A3:和主备一样,AP。

PS:采用类似一致性HASH的各种方式分片存储数据,它的分片并不是分区容错(P),之所以能一致,是因为它基本就是单机。

PS2:可用性(A),它的定义是“任何时刻都可用”,关键是状态的转换是瞬间的(也就没有了中间状态、软状态),也就是数据写入一瞬间,就从1变成了2。

如果在分区容错性(P)情况下需要满足一致性(C),写入必然存在一个写入了节点1,等待写入节点2的这种时间段,这个时间段是不可用的,因此不满足A。也即A、C、P不可共存。

关键字:Redis到底是AP还是CP?

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: