现在的系统已经离不开消息队列,我们可以用他做异步,做解耦,做流处理,做可靠传输。异步消息可以作为解耦消息的生产和处理的一种解决方案,通常会想到两种主要的消息模式——消息队列和发布/订阅模式。常被提到的就是RabbitMQ和Kafka,两者各有优势。参考 (opens new window)
优先选择RabbitMQ的条件:
- 高级灵活的路由规则;
- 消息时序控制(控制消息过期或者消息延迟);
- 高级的容错处理能力,在消费者更有可能处理消息不成功的情景中(瞬时或者持久);
- 更简单的消费者实现。
优先选择Kafka的条件:
- 严格的消息顺序;
- 延长消息留存时间,包括过去消息重放的可能;
- 传统解决方案无法满足的高伸缩能力。
两者结合更优:
例如,在一个事件驱动的架构系统中,我们可以使用RabbitMQ在服务之间发送命令,并且使用Kafka实现业务事件通知。
原因是事件通知常常用于事件溯源,批量操作(ETL风格),或者审计目的,因此Kafka的消息留存能力就显得很有价值。
相反,命令一般需要在消费者端做额外处理,并且处理可以失败,所以需要高级的容错处理能力。