本文主要是介绍Redis到底是AP还是CP?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
这个问题差评,没问清楚。当然,网上一搜,各种各样的狗屁答案都有,有时候是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?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!