一、分布式屏障
分布式barrier一般出现在类似这样的场景,某个任务最终的执行需要基于很多并行计算的子结果。
二、zookeeper实现分布式屏障思路
某个node路径为"/queue_barrier",在该节点下有个子节点给子节点赋值为某个值,假设为10,当根路径"/queue_barrier"下的子节点个数为10时,则所有子进程都完成了任务,主进程开始执行。
基于zookeeper的节点类型,创建临时连续的节点会在创建的节点后给节点名加上一个数字后缀,基于这个顺序,我们可以有如下的思路
1:通过调用getData()来获取某个节点的值,假设为10
2:调用getChildren()来获取所有的子节点,同时注册watcher监听
3:统计子节点的个数
4:将统计的个数和getData()获取的值比较,如果还不足10,就需要等待
5:接收watcher通知
三、看代码