Kafka系列之:消息路由

Kafka系列之:消息路由

一、消息路由

  • 消息路由是消息中间件中常见的一个概念,比如在典型中间件RabbitMQ中就使用路由键RoutingKey来进行消息路由。RabbitMQ中的生产者将消息发送到交换器Exchange中,然后由交换器根据指定的路由键来将消息路由到一个或多个队列中,消费者消费的是队列中的消息。从整体而言,RabbitMQ通过路由键将原本发往一个地方的消息做了区分,然后让不同的消费者消费到自己要关注的消息。
  • Kafka默认按照主题进行路由,消息发往主题之后会被订阅的消费者全盘接收,没有类似消息路由的功能来将消息进行二级路由,这一点从逻辑概念上来说并无任何问题。
  • 从业务应用上而言,如果不同的业务流程复用相同的主题,就会出现消息接收时的混乱,这种问题可以从设计上进行屏蔽,如果需要消息路由,那么完全可以通过细粒度化切分主题来实现。

二、Kafka实现消息路由

  • kafka消费组可以根据消息特定的标识来获取消息,其余的可以被过滤。
  • 具体的实现方式是在消息的header字段加入一个键为routingkey、值为特定业务标识的Header,然后在消费端中使用拦截器挑选出特定业务标识的消息。
  • 消费组ConsumerGroup1根据指定的Header标识rk2和rk3来消费主题TopicA和TopicB中所有对应的消息而忽略Header标识为rk1的消息,消费组ConsumerGroup2正好相反,只消费Header标识为rk1的消息。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

最笨的羊羊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值