JMS中定义了两种消息模型:点对点(point to point, queue)和发布/订阅(publish/subscribe,topic)。主要区别就是是否能重复消费。

点对点:Queue,不可重复消费

消息生产者生产消息发送到queue中,然后消息消费者从queue中取出并且消费消息。
消息被消费以后,queue中不再有存储,所以消息消费者不可能消费到已经被消费的消息。Queue支持存在多个消费者,但是对一个消息而言,只会有一个消费者可以消费、其它的则不能消费此消息了。当消费者不存在时,消息会一直保存,直到有消费消费

发布/订阅:Topic,可以重复消费

消息生产者(发布)将消息发布到topic中,同时有多个消息消费者(订阅)消费该消息。和点对点方式不同,发布到topic的消息会被所有订阅者消费。当生产者发布消息,不管是否有消费者。都不会保存消息
Jms规范里的两种message传输方式Topic和Queue,两者的对比如下
  Topic Queue
概要 Publish  Subscribe messaging 发布订阅消息 Point-to-Point  点对点
有无状态 topic数据默认不落地,是无状态的。

Queue数据默认会在mq服务器上以文件形式保存,比如Active MQ一般保存在$AMQ_HOME\data\kr-store\data下面。也可以配置成DB存储。

完整性保障 并不保证publisher发布的每条数据,Subscriber都能接受到。 Queue保证每条数据都能被receiver接收。
消息是否会丢失 一般来说publisher发布消息到某一个topic时,只有正在监听该topic地址的sub能够接收到消息;如果没有sub在监听,该topic就丢失了。 Sender发送消息到目标Queue,receiver可以异步接收这个Queue上的消息。Queue上的消息如果暂时没有receiver来取,也不会丢失。
消息发布接收策略 一对多的消息发布接收策略,监听同一个topic地址的多个sub都能收到publisher发送的消息。Sub接收完通知mq服务器 一对一的消息发布接收策略,一个sender发送的消息,只能有一个receiver接收。receiver接收完后,通知mq服务器已接收,mq服务器对queue里的消息采取删除或其他操作。

queue与topic的区别相关推荐

  1. ActiveMQ—Queue与Topic区别

    Queue与Topic区别 转自:http://blog.csdn.net/qq_21033663/article/details/52458305 队列(Queue)和主题(Topic)是JMS支持 ...

  2. JMS中queue和topic区别

    JMS中queue和topic区别 2008-07-08 13:16 What is the difference between queue and topic? A connection is c ...

  3. ActiveMQ的queue以及topic两种消息处理机制分析

    转自: http://itindex.net/detail/50057-activemq-queue-topic 上一期介绍了我们项目要用到activeMQ来作为jms总线,并且给大家介绍了activ ...

  4. queue和deque的区别

    queue和deque的区别 queue deque queue 单端队列 queue从队首弹出,先入先出 queue只能从队首删除元素, 但是两端都能访问. queue<int> q; ...

  5. Java中Queue和BlockingQueue的区别

    1.BlockingQueue:支持两个附加操作的 Queue,这两个操作是:检索元素时等待队列变为非空,以及存储元素时等待空间变得可用. 2.BlockingQueue 不接受 null 元素. 3 ...

  6. 5.Queue和Deque的区别与联系

    java的Deque与Queue 1.Queue接口(单向队列) Queue接口,是集合框架Collection的子接口,是一种常见的数据结构,遵循先进先出的原则. 是基于链表来进行实现,的单向队列. ...

  7. Queue与Deque的区别

    前言 ​ 在研究java集合源码的时候,发现了一个很少用但是很有趣的点:Queue以及Deque,平常在写leetcode经常用LinkedList向上转型Deque作为栈或者队列使用,但是一直都不知 ...

  8. spring+ (activeMQ) 实现queue与topic

    2019独角兽企业重金招聘Python工程师标准>>> 2017-06-17 1.activeMQ下载与安装 前往Apache官网下载ActiveMQ,下载地址http://acti ...

  9. 深入理解ActiveMQ支持的2类消息发送接收模型queue和topic

    本文已经收录进专栏,谢谢支持.

最新文章

  1. 中国倒数第五!毕马威全球自动驾驶报告|附下载
  2. CodeForces 392C Yet Another Number Sequence 矩阵快速幂
  3. 程序员笔试面试基础知识资料整理
  4. /etc/passwd 文件详解
  5. 你真的了解NSNotificationCenter吗?
  6. Android新建项目选择SDK的区别
  7. linux安卓双系统板子,安卓迷你 PC 主机只要 109 美元,支持 Android 和 Linux 双系统...
  8. postgresql语句
  9. CodeForces - 1293D Aroma's Search(暴力)
  10. .NET Core Love gRPC
  11. 分布式交换机配置备份和还原
  12. 基于JAVA+SpringMVC+Mybatis+MYSQL的在线商城系统
  13. Java 集合系列18之 Iterator和Enumeration比较
  14. Python爬虫BeautifulSoup4小记
  15. 敏捷团队中有效沟通的5种模式
  16. HDU - 2072 -- 单词数【set or 字典树】
  17. 微信小程序app.json全局配置项
  18. 【第73篇】InternImage:探索具有可变形卷积的大规模视觉基础模型
  19. 侦测卡 变色龙侦测卡 chameleon-Mini(迷你变色龙) (二)
  20. 【数据结构复习自用】树的性质

热门文章

  1. 股指期货跨期套利策略
  2. ETL工具 鱼龙混杂,如何甄选?(开源、包开源、包数据库辅助功能、商用)
  3. pytorch 层标准化 LayerNorm 的用法
  4. 3b学校计算机,3b院校排行_2015年广东3B院校排名参考
  5. vue3.0中找不到组件 或者找不到对应的类型声明。怎么解决
  6. 神经网络 mse一直不变_用深层神经网络解释大脑的运作
  7. 自适应网站与响应式网站的区别在哪?
  8. 丢掉鼠标吧,使用最好用的Eclipse快捷键
  9. 频谱仪的更改ip_通过网口 LAN 开发编程软件远程控制频谱仪DS700
  10. 手机相机里面的m_让手机具备M档 WP专业拍照软件ProShot