您的位置:首页 > 科技 > IT业 > 佛山软件开发培训_个人网站制作模板响应式_西安百度推广联系方式_网站开发北京公司

佛山软件开发培训_个人网站制作模板响应式_西安百度推广联系方式_网站开发北京公司

2025/4/19 13:22:38 来源:https://blog.csdn.net/m0_54712443/article/details/147189553  浏览:    关键词:佛山软件开发培训_个人网站制作模板响应式_西安百度推广联系方式_网站开发北京公司
佛山软件开发培训_个人网站制作模板响应式_西安百度推广联系方式_网站开发北京公司

Zookeeper实现分布式锁

1,zk中锁的种类:
读锁:大家都可以读,要想上读锁的前提:之前的锁没有写锁
写锁:只有得到写锁的才能写。要想上写锁的前提是:之前没有任何锁
2,zk如何上读锁
创建一个临时序号节点,节点的数据是read,表示的是读锁
获取当前zk中序号比自己小的所有节点
判断最小节点是否是读锁:
如果不是读锁的话,则上锁失败,为最小节点设置监听。阻塞等待,zk的watch机制会当最小节点发生变化时通知当前节点,于是再执行第二步的流程
如果时读锁的话,则上锁成功
3,zk如何上写锁
1, 创建一个临时序号节点,节点的数据时write,表示的是写锁
2, 获取zk中所有的子节点
3, 判断自己是否是最小节点:
如果是则上锁成功
不过不是,说明前面还有锁,则上锁失败,监听最小的节点,如果最小节点有变化则回到第二步

羊群效应: 如果用上述的上锁方式,只要有节点发生变化,则会触发其他节点的监听事件,这样的话zk的压力非常大 ----------可以调整成链式监听,解决这个问题

Curator(Zookeeper的客户端)实现读写锁

版权声明:

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

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