Zookeeper分布式协调即分布式锁机制
主要用到的Zookeeper机制:
临时+有序节点,节点watch机制session
过程:
- 发生分布式锁竞争时,参与竞争的各个客户端服务都到Zookeeper的同一父节点(表明着同一把锁)下创建本身的临时+有序子节点,建立成功后子节点名被zk返回给客户端,各客户端保存在本地。
- 全部客户端服务都拉取父节点下的子节点列表,经过对列表排序,将本身本地存储的节点名与列表中的节点名比较:
- 若本地节点与列表中最小的节点相同则表示拿到了锁,此服务获得执行后续逻辑的机会。
- 若本地节点不是列表中最小的,则代表拿锁失败,转而监听比本身小1位的节点在zookeeper中的实际节点,其他节点亦然,从而完成了总体的监听与排队等待。
- 成功得锁的服务执行完毕后就断开与zookeeper的session,zookeeper中与之对应的节点自动删除,此时触发监听。
- 删除节点的事件被下一个服务监听到,又触发它拉取一次列表,作一样的比较,发现本身是最小的节点,此时它拿到了锁,得到执行权限,以此类推各服务互斥的逐个获得执行。
欢迎关注本站公众号,获取更多信息