3,ActiveMQ-入门(基于JMS发布订阅模型)
一、Pub/Sub-发布/订阅消息传递模型
在发布/订阅消息模型中,发布者发布一个消息,该消息通过topic传递给所有的客户端。在这种模型中,发布者和订阅者彼此不知道对方,是匿名的且可以动态发布和订阅topic。topic主要用于保存和传递消息,且会一直保存消息直到消息被传递给客户端。

发布订阅模型就像订阅报纸。我们可以选择一份或者多份报纸,比如:北京日报、人民日报。这些报纸就相当于发布订阅模型中的topic。如果有很多人订阅了相同的报纸,那我们就在同一个topic中注册,对于报纸发行方,它就和所有的订阅者形成了一对多的关系。如下:

二,Pub/Sub特点
1,每个消息可以有多个消费者。
2,发布者和订阅者之间有时间上的依赖性。针对某个主题(Topic)的订阅者,它必须创建一个或多个订阅者之后,才能消费发布者的消息,而且为了消费消息,订阅者必须保持运行的状态。
3,为了缓和这样严格的时间相关性,JMS允许订阅者创建一个可持久化的订阅。这样,即使订阅者没有被激活(运行),它也能接收到发布者的消息。
三,发布订阅模型的实现
3.1,发布者
/**
*
* @类名称:ActiveMQpubsubProducter
* @类描述:发布者-发布订阅模型
*/
public class ActiveMQpubsubProducter {
//会话对象
private static Session session = null; public static void sendMessages(String name){
try {
session = ActiveMQLinkUtil.initConnection(true, Session.AUTO_ACKNOWLEDGE);
if(session != null){
//创建一个主题
Topic messageTopic = session.createTopic(name);
//创建消息发布者
MessageProducer messageProducer = session.createProducer(messageTopic);
for (int i = 0; i < 5 ; i++) {
TextMessage t = session.createTextMessage("ActiveMQ发布消息:" + i);
messageProducer.send(t);
}
session.commit();
}
} catch (Exception e) {
e.printStackTrace();
}
} public static void main(String[] args) {
ActiveMQpubsubProducter.sendMessages("topicDemo");
}
}
3.2,订阅者
----------------------------订阅者1----------------------------
/**
*
* @类名称:ActiveMQpubsubComsumer1
* @类描述:订阅者1-发布订阅模型
*/
public class ActiveMQpubsubComsumer1 {
//会话对象
private static Session session = null; public static void getMessages(String name){
try {
session = ActiveMQLinkUtil.initConnection(false, Session.AUTO_ACKNOWLEDGE);
if(session != null){
Topic topic = session.createTopic(name);
//创建消费者
MessageConsumer messageConsumer = session.createConsumer(topic);
//注册消息监听
messageConsumer.setMessageListener(new MyListener1());
}
} catch (Exception e) {
e.printStackTrace();
}
} public static void main(String[] args) {
ActiveMQpubsubComsumer1.getMessages("topicDemo");
}
}
----------------------------订阅者2----------------------------
/**
*
* @类名称:ActiveMQpubsubComsumer2
* @类描述:订阅者2-发布订阅模型
*/
public class ActiveMQpubsubComsumer2 {
//会话对象
private static Session session = null; public static void getMessages(String name){
try {
session = ActiveMQLinkUtil.initConnection(false, Session.AUTO_ACKNOWLEDGE);
if(session != null){
Topic topic = session.createTopic(name);
//创建消费者
MessageConsumer messageConsumer = session.createConsumer(topic);
//注册消息监听
messageConsumer.setMessageListener(new MyListener2());
}
} catch (Exception e) {
e.printStackTrace();
}
} public static void main(String[] args) {
ActiveMQpubsubComsumer2.getMessages("topicDemo");
}
}
3.3,监听类
----------------------------订阅者1-监听类----------------------------
/**
*
* @类名称:MyListener1
* @类描述:订阅者1-监听类
*/
public class MyListener1 implements MessageListener {
@Override
public void onMessage(Message message) {
try {
System.out.println("订阅者一,收到的消息:" + ((TextMessage)message).getText());
//签收
message.acknowledge();
} catch (JMSException e) {
e.printStackTrace();
}
}
}
----------------------------订阅者2-监听类----------------------------
/**
*
* @类名称:MyListener2
* @类描述:订阅者2-监听类
*/
public class MyListener2 implements MessageListener {
@Override
public void onMessage(Message message) {
try {
System.out.println("订阅者二,收到的消息:" + ((TextMessage)message).getText());
//签收
message.acknowledge();
} catch (JMSException e) {
e.printStackTrace();
}
}
}
四,测试
在点对点的要先启动生产者,生产者要生产消息。而发布订阅模型,要先启动订阅者,订阅者先订阅topic,再发布消息。
第一步:运行ActiveMQpubsubComsumer1,ActiveMQpubsubComsumer2
第二步:运行ActiveMQpubsubProducter
五,结果
ActiveMQpubsubComsumer1:

ActiveMQpubsubComsumer2:

ActiveMQpubsubProducter:

ActiveMQ控制台截图:

|
Number Of Consumers |
在该队列上还有多少消费者在等待接受消息。 |
|
Messages Dequeued |
消费了多少条消息,记做C。 |
|
Messages Enqueued |
生产了多少条消息,记做P。 |
发布者发布了5条数据,但是出队的有10条,因为有两个订阅者。
六,总结
发布者向一个特定的消息主题发布消息,0或者多个订阅者可能接收到来自特定消息主题的消息感兴趣。其中发布者和订阅者不知道对方的存在。
3,ActiveMQ-入门(基于JMS发布订阅模型)的更多相关文章
- RabbitMQ入门_08_所谓的点对点与发布订阅模型
A. JMS 模型 JMS 中定义了点对点和发布订阅两种消息模型,原来以为 AMQP 协议中 direct Exchange 对应点对点模型,topic Exchange 对应发布订阅模型,fanou ...
- JMS发布/订阅消息传送例子
前言 基于上篇文章"基于Tomcat + JNDI + ActiveMQ实现JMS的点对点消息传送"很容易就可以编写一个发布/订阅消息传送例子,相关环境准备与该篇文章基本类似,主要 ...
- windows安装ActiveMQ以及点对点以及发布订阅
一.MQ产品的分类 1.RabbitMQ 是使用Erlang编写的一个开源的消息队列,本身支持很多的协议:AMQP,XMPP, SMTP, STOMP,也正是如此,使的它变的非常重量级,更适合于企业级 ...
- 基于spring-redis发布订阅模式的实现
redis配置: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http ...
- ActiveMQ基于JMS的pub/sub传播机制
原文地址:[ActiveMQ实战]基于JMS的pub/sub传播机制 发布订阅模型 就像订阅报纸,我们可以选择一份或者多份报纸.比如:北京日报.人民日报.这些报纸就相当于发布订阅模型中的topic.如 ...
- 分享一个分布式消息总线,基于.NET Socket Tcp的发布-订阅框架,附代码下载
一.分布式消息总线 在很多MIS项目之中都有这样的需求,需要一个及时.高效的的通知机制,即比如当使用者A完成了任务X,就需要立即告知使用者B任务X已经完成,在通常的情况下,开发人中都是在使用者B所使用 ...
- 基于.NET Socket Tcp的发布-订阅框架
基于.NET Socket Tcp的发布-订阅框架 一.分布式消息总线 在很多MIS项目之中都有这样的需求,需要一个及时.高效的的通知机制,即比如当使用者A完成了任务X,就需要立即告知使用者B任务X已 ...
- NATS—发布/订阅机制
概念 发布/订阅(Publish/subscribe 或pub/sub)是一种消息范式,消息的发送者(发布者)不是计划发送其消息给特定的接收者(订阅者).而是发布的消息分为不同的类别,而不需要知道什么 ...
- ActiveMQ入门系列一:认识并安装ActiveMQ(Windows下)
一.什么是ActiveMQ 度娘给出的定义: Apache ActiveMQ是Apache软件基金会所研发的开放源代码消息中间件:由于ActiveMQ是一个纯Java程序,因此只需要操作系统支持Jav ...
随机推荐
- 关于WordPress中字体加载慢的问题解决方案(转)
2016-04-15 最近发现Wordpress有时候加载的特别慢,于是就想办法找了下原因.之前听网上说是因为wordpress用的是Google的字体库,而且是每次都要加载,导致访问慢的,于是当时装 ...
- sql语句经验
1:拼接字段模糊查询 where aaa(字段) not like CONCAT(DATE_FORMAT(new(),"%Y-%m-%d"),'%完成%'): 2:备份表中数据导 ...
- 分类属性绘图(seaborn的catplot函数)
可以通过指定catplot()函数的kind参数为"bar", "box", "violin"等分别绘制以前提过的柱形图,盒图,小提琴图等. ...
- xmake新增对WDK驱动编译环境支持
xmake v2.2.1新版本现已支持WDK驱动编译环境,我们可以直接在系统原生cmd终端下,执行xmake进行驱动编译,甚至配合vscode, sublime text, IDEA等编辑器+xmak ...
- python面试题--初级(一)
一. Python 中有多少种运算符? 这类面试问题可以判断你的 Python 功底,可以举一些实例来回答这类问题. 在 Python 中我们有 7 中运算符: 算术运算符.关系 (比较) 运算符.赋 ...
- CM使用MySQL数据库预处理scm_prepare_database.sh执行报错:java.sql.SQLException: Access denied for user 'scm'@'hadoop101.com' (using password: YES)
1.报错提示: [root@hadoop101 ~]# /opt/module/cm/cm-/share/cmf/schema/scm_prepare_database.sh mysql cm -hh ...
- MyBatis框架 课程笔记
MyBatis框架 课程笔记 第1章 MyBatis简介 1.1 MyBatis历史 1)MyBatis是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Softw ...
- P2562kitty猫基因
这道题是安徽NOI省选题,但是难度并没有那么难. 这道题是一个字符串的递归题,有很多大佬用线段树来写的(我也想学线段树,lowbit当头一棒).题意为全部相同则输出B或A,不同则分成长度相同的两个子串 ...
- php批量POST修改
这是一个thinkphp中的批量修改的案例: 如需要删除多项,或者同时修改多项记录 要点: 前端表单中name要加[],如:<input type="hidden" name ...
- [51Nod1623] 完美消除
link $solution:$ 首先我们可以发现一个结论,对于一个数 $x$ ,它的最低修改次数为它每位与前去中是否都比此位上的数大,有则答案 $-1$ .因为若有小数则没有办法将其答案贡献变低. ...