消息队列(Message Queue)
1. 什么是消息队列
消息队列是在消息的传输过程中保存消息的容器。
消息队列是典型的生产者、消费者模型。生产者不断的消息队列中产生消息,消费者不断的从队列中获取消息。因为消息的生产和消费是异步的,而且只关心消息的发送和接受,没有业务逻辑的侵入,这样就实现了生产者和消费者的解耦。
2. AMQP 和 JMS
现在实现MQ有两种主流方式:AMQP、JMS。
两种的区别:
- JMS 是定义了统一的接口,来对消息操作进行统一,AMQP是通过规定协议来统一数据交互的形式;
- JMS 限定了必须使用Java语言,AMQP 知识一种协议,不规定方式,因此是跨语言的;
- JMS 规定了两种消息模型,AMQP 的消息模型有五种。
3. 常见的MQ产品
ActiveMQ:基于JMS
RabbitMQ:基于AMQP协议,erlang语言开发,稳定性好
RocketMQ:基于JMS,阿里巴巴产品,目前交由Apache基金会
Kafka:分布式消息系统,高吞吐两
4. 五种消息模型
simple、work、fanout、direct、topic
详细说明链接:https://blog.csdn.net/qsbbl/article/details/82941986
5. 消息持久化
首先生产者交换机持久化
// 声明exchange,指定类型为fanout
channel.exchangeDeclare(EXCHANGE_NAME, "fanout",true);
其次消费者队列持久化
// 声明队列
channel.queueDeclare (QUEUE_NAME, true, false, false, null);
最后消息持久化
// 发送消息,并且指定routing key 为:insert ,代表新增商品
channel.basicPublish(EXCHANGE_NAME, "item.insert", MessageProperties.PERSISTENT_TEXT_PLAIN, message.getBytes());