问题一:为什么要整合ActiveMQ?
传统的JDBC代码在处理连接、语句、结果集和异常时是多么冗长和繁杂你一定不会忘记,传统的JMS继承了JDBC的“关荣传统”。发送一个简单的消息,要几行代码呢?请仔细数数吧。
public void sendMessage() throws JMSException {
ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory(
"tcp://localhost:61616");
Connection connection = null;
Session session=null;
try {
connection = (Connection) connectionFactory.createConnection();//创建连接
session = (Session) connection.createSession(false,
Session.AUTO_ACKNOWLEDGE);//创建会话
Destination destination = session.createQueue("myQueue");
MessageProducer producer = session.createProducer(destination);
TextMessage message = session.createTextMessage(expectedBody);
message.setStringProperty("headname", "remoteB");
producer.send(message);
connection.close();
} catch (Exception e) {
e.printStackTrace();
}finally{
try {
if(session!=null){
session.close();
}
if(connection!=null){
connection=null;
}
} catch (Exception e) {
}
}
}
传统接受消息而是类似的代码,其实我们的目的就是发送和接受消息。幸运的是Spring为我们提供了大量的模板。项目一期用的较多的是JdbCTemplate,spring也为我们提供了JMSTemplate模板。
问题二:JMSTemplate模板该如何配置呢?
类似于jdbcTemplate,首先要配置一个ConnectionFactory,我们采用ActiveMQ5.2作为消息服务器。之后要开始配置JmsTemplate模板了。最后是配置消息目标了。消息分为队列和主题两大类,因此要配置两个消息目标了。
<!-- ActiveMQ -->
<!-- 配置JMS连接工厂 -->
<bean id="JmsConnectionFactory" class="org.apache.activemq.spring.ActiveMQConnectionFactory">
<property name="brokerURL" value="tcp://localhost:61616"/>
</bean>
<!-- 配置JMS模版 -->
<bean id="JmsTemplate" class="org.springframework.jms.core.JmsTemplate">
<property name="connectionFactory" ref="JmsConnectionFactory"/>
</bean>
<!-- 发送消息的目的地(队列) -->
<bean id="QueueDestination" class="org.apache.activemq.command.ActiveMQQueue">
<!-- 设置消息队列的名字 -->
<constructor-arg index="0" value="HelloWorldQueue"/>
</bean>
<!-- 发送消息的目的地(主题) -->
<bean id="TopicDestination" class="org.apache.activemq.command.ActiveMQTopic">
<!-- 设置消息主题的名字 -->
<constructor-arg index="0" value="FlexTopic"/>
</bean>
问题三:如何使用JmsTemplate发送消息呢?
spring的beanfactory得到一个jmsTemplate的实例和消息目标的实例,发送消息,够简单的吧。看看代码:
JmsTemplate template = (JmsTemplate) SpringContext.getBean("JmsTemplate");
ActiveMQTopic destination=(ActiveMQTopic)SpringContext.getBean("TopicDestination");
template.send((javax.jms.Destination) destination, new MessageCreator(){
public Message createMessage(Session session) throws JMSException {
return session.createTextMessage("hello");
}
});
问题四:上面的代码能不能在简单些?
很多时候,发送消息的目标都是默认的,因此是不是可以在jmsTemplate中设置一个默认的消息目标呢?答案是肯定的。
<!-- 配置JMS模版 -->
<bean id="JmsTemplate" class="org.springframework.jms.core.JmsTemplate">
<property name="connectionFactory" ref="JmsConnectionFactory"/>
<property name="defaultDestination" ref="TopicDestination"></property>
</bean>
发送消息的时候,不指定目标,spring就会调用默认的目标了。
JmsTemplate template = (JmsTemplate) SpringContext.getBean("JmsTemplate");
template.send( new MessageCreator(){
public Message createMessage(Session session) throws JMSException {
return session.createTextMessage("hello");
}
});
问题四:jmsTemplate怎么接受信息?
jmsTemplate接收消息十分的简单,只需要调用template.receive()方法,receive方法是同步的,默认情况下,对receive()方法的调用会造成阻塞,知道消息到达目标----如果必要,永远等下去。为了避免对消息内容等待,可以配置jmsTemplate时,通过设置receiveTimeout属性来指定接收消息超时时间。下面的配置将接收消息的超时时间设置为一分钟(60000毫秒)。
<!-- 配置JMS模版 -->
<bean id="JmsTemplate" class="org.springframework.jms.core.JmsTemplate">
<property name="connectionFactory" ref="JmsConnectionFactory"/>
<property name="defaultDestination" ref="TopicDestination"></property>
<property name="receiveTimeout" value="60000"></property>
</bean>
template.receive()会从默认目标接收消息,如果你希望指定一个目标,可以传一个目标。如:template.receive("myQueue").
同步接收消息并不是spring唯一的选择,消息监听器可以实现异步(下篇文章将会介绍消息驱动)。
问题五:怎么自动将消息转化为Java对象?
转化器在很多组件中都是必不缺少的东西。Spring挺过MessageConverter接口提供了对消息转换的支持。
public class MyMessageConverter implements MessageConverter {
@Override
public Object fromMessage(Message arg0) throws JMSException,
MessageConversionException {
// TODO Auto-generated method stub
return null;
}
@Override
public Message toMessage(Object arg0, Session arg1) throws JMSException,
MessageConversionException {
// TODO Auto-generated method stub
return null;
}
}
MessageConverter接口的两个方法简单明了。在发送端toMessage会将java对象转化为消息,在接收端fromMessage会将消息转化为java对象。
下面的代码简单的实现了MessageConverter的两个接口。
public class MyMessageConverter implements MessageConverter {
@Override
public Object fromMessage(Message message) throws JMSException,
MessageConversionException {
if(!(message instanceof MapMessage)){
throw new MessageConversionException("Messae is not MapMessage");
}
MapMessage mapMessage=(MapMessage)message;
MessageObj messageObj=new MessageObj();
messageObj.setId(mapMessage.getString("id"));
messageObj.setInfo(mapMessage.getString("info"));
return messageObj;
}
@Override
public Message toMessage(Object obj, Session session) throws JMSException,
MessageConversionException {
if(!(obj instanceof MessageObj)){
throw new MessageConversionException("obj is not MessageObj");
}
MessageObj messageObj=(MessageObj)obj;
MapMessage mapMessage=session.createMapMessage();
mapMessage.setString("id", messageObj.getId());
mapMessage.setString("info", messageObj.getInfo());
return mapMessage;
}
}
此时,发送和接收消息要换成template.convertAndSend(message);template.receiveAndConvert();
可是jmsTemplate如何知道消息转换器呢?需要在配置jmsTemplate的时候,加上messageConverter属性。
<!-- 配置JMS模版 -->
<bean id="JmsTemplate" class="org.springframework.jms.core.JmsTemplate">
<property name="connectionFactory" ref="JmsConnectionFactory"/>
<property name="defaultDestination" ref="TopicDestination"></property>
<property name="receiveTimeout" value="60000"></property>
<property name="messageConverter" ref="messageObj"></property>
</bean>
messageObj是要转化的java对象的bean的id。
分享到:
相关推荐
整合Spring和ActiveMQ可以帮助我们构建可扩展的、高可用性的系统,通过消息队列实现应用间的解耦,提高系统的响应速度和并发处理能力。这个完整的实例是一个很好的学习资源,可以帮助开发者更好地理解和实践Spring与...
Spring集成ActiveMQ配置详解 Spring框架与ActiveMQ的集成,为...然而,值得注意的是,随着技术的发展,Spring和ActiveMQ的版本也在不断更新,因此,在实际项目中,应当根据最新的文档和实践来进行相应的调整和优化。
详细内容: SpringJMS整合ActiveMQ.doc 详细说明文档 apache-activemq-5.8.0-bin.zip ActiveMQ安装包 JMSTest.rar MyEclipse8.5下web工程
而Spring框架,作为一个Java平台的全功能模块化解决方案,提供了与ActiveMQ集成的能力,让开发者能够轻松地在Spring应用中使用消息队列。本篇将深入探讨Spring与ActiveMQ的集成及其配置过程。 首先,理解Spring与...
总结,`spring整合Activemq源码`项目展示了如何在Spring和SpringMVC环境中利用ActiveMQ实现消息的发布与订阅。通过理解这些知识点,开发者能够更好地理解和实践消息队列在实际项目中的应用,提升系统的稳定性和扩展...
在实际应用中,Spring和ActiveMQ的结合可以用于实现如下的功能: - **解耦组件**:通过消息传递,生产者和消费者可以独立开发和升级,互不影响。 - **负载均衡**:消息队列可以缓冲消息,防止高峰期对系统的冲击。 ...
10. **Tomcat服务器**:Tomcat是一个流行的Java Web服务器,它可以部署和运行使用Spring和ActiveMQ的Web应用程序。 通过上述知识点,我们可以理解如何在Spring环境中利用ActiveMQ进行消息传递,实现高并发、解耦的...
Spring框架和ActiveMQ的结合使用,为开发者提供了强大的异步消息传递能力。本文将深入探讨如何结合Spring 2.0与ActiveMQ来实现异步消息调用,并分享相关知识点。 首先,Spring 2.0是一个广泛使用的Java应用框架,它...
以上就是关于 ActiveMQ-P2P 文本消息以及 Spring 和 ActiveMQ 整合实例的相关知识点。通过这些知识,开发者可以构建起可靠的点对点消息传递系统,提高应用的可扩展性和解耦性。在实际项目中,根据具体需求,还可以...
在 Spring Boot 中整合 ActiveMQ,可以使用 Spring 的 JmsTemplate 或者 @JmsListener 注解来发送和接收消息,实现应用间的异步通信和解耦。 整合以上技术的过程通常包括以下步骤: - 添加对应库的依赖,如 spring...
在这个项目中,我们将探讨如何将Spring Boot与Apache ActiveMQ、DataJPA和Ehcache进行集成,以构建一个功能丰富的应用程序。 首先,ActiveMQ是Apache出品的一款开源消息中间件,它遵循Java Message Service (JMS) ...
1. 引入依赖:首先,在项目中添加ActiveMQ和Spring相关的依赖库。通常在Maven或Gradle的pom.xml或build.gradle文件中配置如下依赖: - Apache ActiveMQ: ```xml <groupId>org.apache.activemq <artifactId>...
在`pom.xml`文件中,我们需要添加`spring-boot-starter-jms`和`activemq-client`依赖,以便利用Spring JMS API和ActiveMQ客户端库。 ```xml <groupId>org.springframework.boot <artifactId>spring-boot-...
最后,**高级特性**:Spring和ActiveMQ还支持更复杂的消息处理模式,如主题(Topic)订阅、消息分发策略、消息优先级和消息组等。这些特性可以帮助开发者构建更健壮、灵活的消息系统。 总结,Spring与ActiveMQ的集...
将Spring Boot与ActiveMQ集成可以提供强大的消息处理能力,使应用能够解耦组件,提高可扩展性和容错性。 本文将详细讲解如何使用Spring Boot与内置的ActiveMQ进行集成,以及如何通过代码实现这一过程。 首先,我们...
在IT行业中,Spring框架是Java应用开发的基石,而ActiveMQ则是Apache组织开发的一款开源的消息中间件,用于处理异步通信和消息队列。本文将深入探讨如何在Spring环境中使用ActiveMQ来实现消息的发送与接收,以提高...
在构建基于Spring和ActiveMQ的应用时,Tomcat可以作为部署环境,承载应用的Web容器部分。 构建JMS系统通常涉及到以下步骤: 1. **配置Spring**: 首先,在Spring的配置文件(如`applicationContext.xml`)中定义JMS...
在"spring配置activemq详解"这个主题中,我们将探讨如何在Spring项目中配置和使用ActiveMQ。以下是对这个主题的详细说明: 1. **配置ActiveMQ**: - 首先,我们需要在项目中引入ActiveMQ的相关依赖,这通常通过在`...