druid-docs-cn/design/Zookeeper.md

61 lines
2.3 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!-- toc -->
<script async src="https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script>
<ins class="adsbygoogle"
style="display:block; text-align:center;"
data-ad-layout="in-article"
data-ad-format="fluid"
data-ad-client="ca-pub-8828078415045620"
data-ad-slot="7586680510"></ins>
<script>
(adsbygoogle = window.adsbygoogle || []).push({});
</script>
## ZooKeeper
Apache Druid使用[Apache ZooKeeper](http://zookeeper.apache.org/) 来管理整个集群状态。通过ZK来进行的操作有
1. [Coordinator](Coordinator.md) Leader选举
2. [Historical](Historical.md) 段发布协议
3. [Coordinator](Coordinator.md) 和 [Historical](Historical.md) 之间的段加载/删除
4. [Overlord](Overlord.md) Leader选举
5. [Overlord](Overlord.md)和[MiddleManager](MiddleManager.md)任务管理
### Coordinator Leader选举
我们使用 **Curator LeadershipLatch** 进行Leader选举
```json
${druid.zk.paths.coordinatorPath}/_COORDINATOR
```
### Historical和Realtime之间的段发布
`announcementsPath``servedSegmentsPath` 这两个参数用于这个功能。
所有的 [Historical](Historical.md) 进程都将它们自身发布到 `announcementsPath`, 具体来说它们将在以下路径创建一个临时的ZNODE
```json
${druid.zk.paths.announcementsPath}/${druid.host}
```
这意味着Historical节点可用。它们也将随后创建一个ZNODE:
```json
${druid.zk.paths.servedSegmentsPath}/${druid.host}
```
当它们加载段时它们将在以下路径附着的一个临时的ZNODE
```json
${druid.zk.paths.servedSegmentsPath}/${druid.host}/_segment_identifier_
```
然后,[Coordinator](Coordinator.md) 和 [Broker](Broker.md) 之类的进程可以监视这些路径,以查看哪些进程当前正在为哪些段提供服务。
### Coordinator和Historical之间的段加载/删除
`loadQueuePath` 参数用于这个功能。
当 [Coordiantor](Coordinator.md) 决定一个 [Historical](Historical.md) 进程应该加载或删除一个段时它会将一个临时znode写到:
```json
${druid.zk.paths.loadQueuePath}/_host_of_historical_process/_segment_identifier
```
这个znode将包含一个payload它向Historical进程指示它应该如何处理给定的段。当Historical进程完成任务时它将删除znode以便向Coordinator表示它已经完成处理。