Druid Broker Nodes

Druid集群的Broker节点主要负责客户端请求的路由和合并查询结果返回给客户端。Broker节点在启动时会加载zookeeper中segment的位置信息,在客户端请求到来时,会根据这些segment的位置信息,将请求路由到响应的historical节点或real-time节点。

每个Broker节点都有一个本地缓存,用来缓存最近查询的结果,并采用LRU失效策略来淘汰数据。

每次Broker接收到查询请求后,会将查询请求映射到缓存中的一组相应的segment上,部分segment可能存在缓存中,就无需重复计算;如果不存在,就会请求转发到相应的historical节点,一旦historical节点返回查询结果,就将这些segment放到缓存中,以供后续重复使用。整个过程如下图:

 

此外,Broker节点不会缓存Real-time节点的segment数据,因为Real-time节点的数据总是在变化的,做缓存无意义。所以查询请求总是被转发到Real-time节点。

对于Broker节点,如果在zookeeper变得不可用了,这些节点仍是可以提供查询的,只不过查询的是缓存中的数据。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值