SpringBoot高级——消息中间件
一、概述 1、大多应用中,可通过消息服务中间件来提升系统异步通信、扩展解耦能力 2、消息服务中的两个重要概念:消息代理(message broker,即消息中间件服务器)和目的地(destination) 当消息发送者发送消息以后,将由消息代理接管,消息代理保证消息传递到指定目的地。 3、消息队列主要有两种形式的目的地 队列(queue):点对点消息通信(point-to-point) 消息发送者发送消息,消息代理将其放入一个队列中,消息接收者从队列中获取消息内容,消息读取后被移出队列 消息只有唯一的发送者和接受者,但并不是说只能有一个接收者,这是因为消息一旦被消费就会从队列中移除 主题(topic):发布(publish)/订阅(subscribe)消息通信 发送者(发布者)发送消息到主题,多个接收者(订阅者)监听(订阅)这个主题,那么就会在消息到达时同时收到消息,不同于点对点的方式,在点对点的方式中一旦一个接收者处理了消息,消息就会被移除,那么其他的接收者就不会再去处理,而订阅的方式则是所有的接收者都会对该消息做出相应处理 二、使用场景 1、异步处理 在用户注册时给用户发送短信和邮件,但是短信和邮件并不需要在注册成功已完成就发送,因此可以异步处理 2、应用解耦 3、流量削峰 比如秒杀:在10万个客户秒杀1万个商品的时候