分布式系统中必备的一个中间件就是消息队列,通过消息队列我们能对服务间进行异步解耦、流量消峰、实现最终一致性。
目前市面上已经有 RabbitMQ、RochetMQ、ActiveMQ、Kafka
等,有人会问:“Redis 适合做消息队列么?”
在回答这个问题之前,我们先从本质思考:
- 消息队列提供了什么特性?
- Redis 如何实现消息队列?是否满足存取需求?
今天,码哥结合消息队列的特点一步步带大家分析使用 Redis 的 List 作为消息队列的实现原理,并分享如何把 SpringBoot 与 Redission 整合运用到项目中。
而 Kafka、RabbitMQ 部署时,涉及额外的组件,例如 Kafka 的运行就需要再部署 ZooKeeper。相比 Redis 来说,Kafka 和 RabbitMQ 一般被认为是重量级的消息队列。
需要注意的是,我们要避免生产者过快,消费者过慢导致的消息堆积占用 Redis 的内存。
在消息量不大的情况下使用 Redis 作为消息队列,他能给我们带来高性能的消息读写,这似乎也是一个很好消息队列解决方案。