Kafka系列之:消息路由

Kafka系列之:消息路由

  • 一、消息路由
  • 二、Kafka实现消息路由

一、消息路由

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

二、Kafka实现消息路由

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

你可能感兴趣的:(日常分享专栏,Kafka系列,消息路由)