1. 简介
MQ(Message Queue)消息队列是一种应用程序对应用程序的通信方法,应用程序通过读(出队)写(入队)队列的消息(针对应用程序的数据)进行通信。
MQ是消费者-生产者模型的典型代表,生产者往消息队列中不断写入消息,而消费者则可以读取或者订阅队列中的消息,并进行消息处理。
消息队列中间件是分布式系统中非常重要的组件,可适用于异步处理、应用解耦、流量削锋、消息通讯、日志处理等场景,实现高性能、高可用、可伸缩和最终一致性架构,是大型分布式系统中不可缺少的中间件。
比较常用的消息队列中间件主要有ActiveMQ、RabbitMQ、Kafka、RocketMQ、ZeroMQ等,甚至可以用Redis来构造消息队列作为轻量级的消息队列服务使用。
2. 使用场景
2.1 异步处理
场景说明:用户注册后,需要发注册邮件和注册短信。
传统的做法有两种:串行方式和并行方式。
- 串行方式:将用户的注册信息写入数据库后,先发送注册邮件,再发送注册短信。三个任务全部完成后,返回给客户端。
- 并行方式:将用户的注册信息写入数据库后,发送注册邮件的同时,发送注册短信。三个任务全部完成后,返回给客户端。Java支持多线程,可实现并行方式。
假设每个业务节点的开销是50毫秒,则串行方式的响应时间为150ms,并行方式的响应时间为100ms。串行方式下CPU单位时间内处理的请求数不到7个,并行方式下CPU单位时间内处理的请求数为10个。
传统的做法,系