初识消息队列

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());
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值