参考:php+redis实现消息队列 - 巴八灵 - 博客园
参考:大型网站架构之分布式消息队列_shao.bing的专栏-CSDN博客_消息队列
消息队列:是在消息的传输过程中保存消息的容器。消息队列管理器在将消息从它的源中继到它的目标时充当中间人。队列的主要目的是提供路由并保证消息的传递;如果发送消息时接收者不可用,消息队列会保留消息,直到可以成功地传递它
应用场景:异步处理,应用解耦,流量削锋和消息通讯四个场景
1、异步处理
场景说明:用户注册后,需要发注册邮件和注册短信。
注解:自行考虑ajax中的异步。
2、应用解耦
一般订单系统和库存系统是一体的,但是如果一方出现问题,那么这个订单就失败了。
- 订单系统:用户下单后,订单系统完成持久化处理,将消息写入消息队列,返回用户订单下单成功。
- 库存系统:订阅下单的消息,采用拉/推的方式,获取下单信息,库存系统根据下单信息,进行库存操作。
- 假如:在下单时库存系统不能正常使用。也不影响正常下单,因为下单后,订单系统写入消息队列就不再关心其他的后续操作了。实现订单系