- 浏览: 395209 次
- 性别:
- 来自: 北京
-
文章分类
最新评论
-
fuchenggangs:
手动抛出异常后想要自动回滚@Transactional(rol ...
spring mvc 与JPA/Hibernate的整合示例 -
springdata_spring:
可以参考最新的文档:如何在eclipse jee中检出项目并转 ...
利用eclipse构建和部署maven工程 -
hzw2312:
好像这个事务不起作用呀!
@Transactional(rea ...
spring mvc 与JPA/Hibernate的整合示例 -
huhuhuhh:
类目清晰,感谢分享!
spring mvc 与JPA/Hibernate的整合示例 -
endual:
菜鸟问下,<!-- Spring Data Jpa配置 ...
spring mvc 与JPA/Hibernate的整合示例
其实学习activeMQ的初衷就是要找一个能够实现异步消息的发布/订阅机制的解决方案。
一、要启动消息代理
也就是一个broker.在上一篇中,我是自建了一个内嵌的broker. 经过进一步的了解,实际上利用官方的代理才是最常见的应用场景。
这里直接执行官方解压包下的activemq.bat
若是要启动特定配置的broker.先确认配置文件如activemq-demo.xml存在于conf下。执行:
二、创建消息发布者
在一个java 工程中来创建发布者类
三、创建消息订阅者
在一个java工程中创建订阅者类
四、测试
1、运行发布者类TopicProducer.java.在确认成功后。
2、运行订阅者类TppicConsumer.java.可以看到所有的消息都被接收过来了。
3、还可以修改发布者的主题(topic)后测试,发现订阅者接受到不任务消息。
4、还可以确认两个客户端的主题一致的前提下,在发布完成后,将发布者停止后,再启动订阅者。可以发现订阅都照样可以接受该主题的消息,这一切说明持久化的发布/订阅是成功了!
五、小结:
1、推荐使用官方的broker.
2、两个客户端(发布者和订阅者)都要设置相同的主题,即:
3、若是希望订阅者能够事后接收在它不活时所发布的消息,必须为订阅者设置ID,即:
这个id可以随意起名,会在订阅者第一次连接broker时,注册到代理服务器上。
一、要启动消息代理
也就是一个broker.在上一篇中,我是自建了一个内嵌的broker. 经过进一步的了解,实际上利用官方的代理才是最常见的应用场景。
这里直接执行官方解压包下的activemq.bat
若是要启动特定配置的broker.先确认配置文件如activemq-demo.xml存在于conf下。执行:
./activemq xbean:activemq-demo.xml
二、创建消息发布者
在一个java 工程中来创建发布者类
package test.mq; import javax.jms.Connection; import javax.jms.DeliveryMode; import javax.jms.JMSException; import javax.jms.MessageProducer; import javax.jms.Session; import javax.jms.TextMessage; import javax.jms.Topic; import org.apache.activemq.ActiveMQConnectionFactory; public class TopicProducer { public static void main(String[] args) throws JMSException { ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory("tcp://localhost:61616"); Connection connection = factory.createConnection(); connection.start(); Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); Topic topic = session.createTopic("Topics.alert"); MessageProducer producer = session.createProducer(topic); producer.setTimeToLive(60000); //设定消息过期时间 //producer.setDeliveryMode(DeliveryMode.PERSISTENT); //设置消息的持久化为永不过期 int i= 1; while(i<10) { TextMessage message = session.createTextMessage(); message.setText("message_"+ i +" : "+ System.currentTimeMillis()); producer.send(message); System.out.println("Sent message: " + message.getText()); i++; try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } } // session.close(); // connection.stop(); // connection.close(); } }
三、创建消息订阅者
在一个java工程中创建订阅者类
package test.mq; import javax.jms.Connection; import javax.jms.JMSException; import javax.jms.Message; import javax.jms.MessageListener; import javax.jms.Session; import javax.jms.TextMessage; import javax.jms.Topic; import javax.jms.TopicSubscriber; import org.apache.activemq.ActiveMQConnectionFactory; public class TopicConsumer { public static void main(String[] args) throws JMSException { ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory("tcp://localhost:61616"); Connection connection = factory.createConnection(); //factory.createTopicConnection();// //若是持久订阅,这里必须设置当前订阅者的id,并在第一次运行时注册到borker上 connection.setClientID("zhangsan"); connection.start(); Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); Topic topic = session.createTopic("Topics.alert"); //MessageConsumer consumer = session.createConsumer(topic); //如果是持久订阅,用下面的两行,替代上面的一行 TopicSubscriber subscriber = session.createDurableSubscriber(topic, "zhangsan"); subscriber.setMessageListener(new MessageListener() { //consumer.setMessageListener(new MessageListener() { public void onMessage(Message message) { TextMessage tm = (TextMessage) message; try { System.out.println("Received message: " + tm.getText()); } catch (JMSException e) { e.printStackTrace(); } } }); // session.close(); // connection.stop(); // connection.close(); } }
四、测试
1、运行发布者类TopicProducer.java.在确认成功后。
2、运行订阅者类TppicConsumer.java.可以看到所有的消息都被接收过来了。
3、还可以修改发布者的主题(topic)后测试,发现订阅者接受到不任务消息。
4、还可以确认两个客户端的主题一致的前提下,在发布完成后,将发布者停止后,再启动订阅者。可以发现订阅都照样可以接受该主题的消息,这一切说明持久化的发布/订阅是成功了!
五、小结:
1、推荐使用官方的broker.
2、两个客户端(发布者和订阅者)都要设置相同的主题,即:
Topic topic = session.createTopic("Topics.alert"); //Topics.alert就是主题名
3、若是希望订阅者能够事后接收在它不活时所发布的消息,必须为订阅者设置ID,即:
connection.setClientID("zhangsan");
这个id可以随意起名,会在订阅者第一次连接broker时,注册到代理服务器上。
发表评论
-
spring mvc 与JPA/Hibernate的整合示例
2013-07-17 16:53 36128一、首先通过maven加入spring、jpa和hiberna ... -
【JPA】基础知识
2012-03-04 20:22 1091JPA是java编程领域的ORM标准。最著名的参考实现是hib ... -
JAXB的基本应用
2012-02-29 00:13 1417JAXB(Java API for XML Binding)是 ... -
log4j的应用与配置
2012-01-31 22:25 1353在java编程领域,log4j已经是事实上的日志输出工具。不但 ... -
springsecurity学习笔之二:实现一个基于数据库的简单权限系统
2012-01-23 14:35 2183这里在一个web工程中,通过三张表,实现用户、角色、权限的关系 ... -
springsecurity学习笔记之一:安全架构的理解
2012-01-20 09:45 1654计划将springsecurity的引入新的项目中。开始学习。 ... -
activeMO学习笔记一:开始自己的第一个mq
2012-01-14 14:01 1636因为项目的需要,在构思系统的架构设计上,想到了ActiveMQ ... -
cxf学习笔记之传递附件
2012-01-12 09:34 4793cxf是jws的实现,上传二进制文件主要借助MTOM来实现,只 ... -
cxf学习笔记之传递复杂对象
2012-01-10 14:52 3850设计思路,创建一个人员注册的web服务。接受客户端传递的人员信 ... -
ie的进度条总也走不完
2011-01-11 21:06 1242多年前就发现跑着的系统中,时常看见ie的进度条总也走不完。但事 ... -
什么是工作流?
2010-12-29 18:53 1033项目要用到工作流,给自己补一课。 就是“业务过程的部分或整体 ... -
特定环境下的应用服务器的时差问题
2010-04-02 10:59 1334最近遇到希望的问题。在window2008+weblogic1 ... -
给tomcat的Dos窗口命名
2010-01-07 14:04 3236做javaee开发,离不了web容器,tomcat可以说是最常 ... -
cxf学习笔记之结合spring创建客户端
2009-12-28 18:46 1618这个比较迷惑人。。。至少对我这个初学者来说是如此。后面解释原因 ... -
cxf学习笔记之结合spring创建服务端
2009-12-28 18:43 2215刚起步时实际上服务端是最简单的。 一、加入cxf支持 简单的说 ... -
cxf学些过程中的一些问题
2009-12-27 18:24 38291、 2009-12-27 18:19:02 org.apac ... -
数据源的两种配置
2009-10-09 10:27 1220开发的应用系统通常可以对数据源进行多种配置。 1、开发过程中往 ... -
常量类与属性文件在开发中的使用技巧
2009-08-13 16:48 1089开发中经常会将一些常用的或常修改的数据记录到常量类或属性文件中 ... -
过滤器在web开发中的应用
2009-04-07 15:53 1107在现在的web开发中,使用Filter来完成一些支撑性的工作是 ... -
mvn and ssh融合问题及解决办法
2009-03-27 09:32 3663通过maven融合ssh(struts2+spring2.5+ ...
相关推荐
计算机二级算法重点.doc
【目标检测】脚印检测数据集819张YOLO+VOC.docx
网络广告的现状及未来发展.docx
【目标检测】12种家具家电检测数据集7656张YOLO+VOC格式.docx
电大C语言程序设计期末考试试题A.doc
网络营销测试试卷.docx
自学考试管理系统中的计算机应用试题和答案.doc
西南大学网络与继续教育学院课程考试试题汽车文化.doc
电子商务系统分析与设计开发技术.doc
江苏省中小学教师健康知识网络竞赛含答案.doc
计算机系统集成项目经理聘用协议书.doc
电大操作系统本期末复习材料新版.doc
内容概要:本文档详细介绍了MySQL 8.0版本的安装与配置流程,包括下载、安装、环境配置以及环境变量的设置。首先,介绍了MySQL的下载方式,区分了在线安装和离线安装的特点,并推荐离线安装。接着,逐步讲解了安装过程中不同安装类型的选项,如开发者默认、仅服务器、仅客户端、完整安装和自定义安装,并重点描述了自定义安装的步骤,包括选择版本、设置安装路径和数据存储路径、配置环境(对于未安装环境的计算机)、安装MySQL、选择网络类型、设置身份验证方法和密码。最后,指导用户配置环境变量,并提供了检查环境变量配置是否成功的具体方法。 适合人群:适合初次接触MySQL数据库的用户,尤其是需要在本地计算机上搭建MySQL环境的学习者或开发者。 使用场景及目标:①帮助用户从零开始搭建MySQL 8.0环境,适用于个人学习或小型项目开发;②确保用户能够顺利完成MySQL的安装与配置,掌握基本的操作技能;③为后续深入学习MySQL提供必要的基础支持。 阅读建议:由于安装过程涉及多个步骤,建议读者按照文档中的顺序逐步操作,遇到问题时仔细检查每一步的设置是否正确,同时注意根据自己的实际需求选择合适的安装类型和配置选项。
要服务委托协议服务网络覆盖区域.docx
秋东财建设工程项目管理在线作业二参考答案.docx
微信自定义表情包导出功能,python
秋季电大湖南省开课程网络形考电子商务概论第二次作业分答案至章.doc
电大高级财务会计第三次作业答题网络.doc
(1)熟悉并阐述不同空间目标的轨道分类与特点; (2)能够独立完成空间目标轨道建模与计算; (3)能够应用MATLAB和STK仿真软件完成空间目标轨道计算与仿真。
【目标检测】X光手骨关节检测数据集8930张YOLO+VOC格式.docx