zk可实现分布式锁,Redis也可实现,之间有什么区别?

本文探讨了Zookeeper实现的CP分布式锁与Redis实现的AP分布式锁的工作原理和特性。CP锁确保数据一致性,但可能牺牲实时性;而AP锁追求高可用,可能导致数据不一致。理解两者选择的关键在于业务需求和数据一致性要求。
摘要由CSDN通过智能技术生成

提示:
1.CAP模型
2.数据同步及时性

答案:
使用 zk 实现的分布式锁是 CP 的分布式锁。因为 zk 是 CP 的。在某客户端向 zk 集群中的某节点写入数据后,会等待超过半数的其它节点完成同步后,才会响应该客户端。

使用 Redis 实现的分布式锁是 AP 的分布式锁。因为 Redis 是 AP 的。在某客户端向 Redis集群中的某节点写入数据后,会立即响应该客户端,之后在 Redis 集群中会以异步的方式来同步数据。

对于 AP 的分布式锁,需要注意可能会出现的问题:一个客户端 a 在 Redis 集群的某节点 A 写入数据后,另一个节点 B 在还未同步时,另一个客户端 b 从 B 节点读取数据,没有发现 a 写入的数据。此时可能会出现问题。所以,如果某共享资源要求必须严格按照锁机制进行访问,那么就使用 zk 实现的 CP 锁。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值