消息队列中间件是分布式系统中重要的组件,主要解决异步消息、应用耦合、流量削锋等问题。实现高性能,高可用,可伸缩和最终一致性架构。是大型分布式系统不可缺少的中间件。
目前在生产环境,使用较多的消息队列有ActiveMQ,RabbitMQ,ZeroMQ,Kafka,MetaMQ,RocketMQ等。
应用场景
异步消息
场景说明:用户注册后,需要发注册邮件和注册短信。传统的做法有两种:1、串行的方式,2、并行方式。
(1)串行方式:将注册信息写入数据库成功后,发送注册邮件,再发送注册短信。以上三个任务全部完成后,返回给客户端。
(2)并行方式:将注册信息写入数据库成功后,发送注册邮件的同时,发送注册短信。以上三个任务完成后,返回给客户端。与串行的差别是,并行的方式可以提高处理的时间。
引入消息队列。用户注册信息写入数据库完成后,注册邮件,发送短信写入消息队列后,直接返回。因此写入消息队列的速度很快,基本可以忽略,整个请求时间只相当于注册信息写入数据库的时间。
应用耦合
场景说明:用户下单后,订单系统需要通知库存系统。传统的做法是,订单系统调用库存系统的接口。如果库存系统扣减库存失败,会导致下单失败。
使用消息队列,则可以避免这个问题。用户下单后,会在消息队列中写入扣减库存的信息,然后返回。
并发
待完善
流量削峰
待完善
日志处理
待完善