ActiveMQ集成spring
2017-09-26 10:46
309 查看
1.pom 导入jar包
<dependency> <groupId>org.apache.activemq</groupId> <artifactId>activemq-all</artifactId> <version>5.15.0</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.8.1</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.3.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>4.3.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>4.3.9.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jms</artifactId> <version>4.3.9.RELEASE</version> </dependency> <dependency> <groupId>org.apache.activemq</groupId> <artifactId>activemq-core</artifactId> <version>5.7.0</version> <exclusions> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> </exclusion> </exclusions> </dependency>
2.编写一个 spring-activemq-common.xml 配置文件,放消息的提供和消费的公共配置
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <context:component-scan base-package="com.spf.activemq.spring" /><!--ActiveMQ提供的ConnectionFactory--><bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory"><property name="brokerURL" value="tcp://192.168.1.125:61616"/></bean><!--Spring jms 提供的连接池--><bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory"><property name="targetConnectionFactory" ref="targetConnectionFactory"/></bean><!--一个队列的目的地 点对点--><bean id="queueDestination" class="org.apache.activemq.command.ActiveMQQueue"><constructor-arg value="spf-queue" /></bean><!--一个主题的目的地 点对点--><bean id="topicDestination" class="org.apache.activemq.command.ActiveMQTopic"><constructor-arg value="spf-topic" /></bean></beans>
3.编写一个 spring-activemq-producer.xml 配置文件,消息的提供
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <context:component-scan base-package="com.spf.activemq.spring" /><import resource="spring-activemq-common.xml"/><!--配置消息发送模板--><bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate"><property name="connectionFactory" ref="connectionFactory"/><property name="defaultDestination" ref="queueDestination"/></bean><!--队列发送--><bean class="com.spf.activemq.spring.producer.ProducerQueueServiceImpl"><property name="jmsTemplate" ref="jmsTemplate"/></bean><!--主题发送--><bean class="com.spf.activemq.spring.producer.ProducerTopicServiceImpl"><property name="topicJmsTemplate" ref="jmsTemplate"/></bean></beans>4.spring-activemq-customer.xml 配置消息的消费
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <context:component-scan base-package="com.spf.activemq.spring" /><import resource="spring-activemq-common.xml"/><!--配置消息监听器--><bean id="queueMessageListener" class="com.spf.activemq.spring.customer.MessageListener"></bean><!--配置消息容器--><bean id="jmsContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer"><property name="connectionFactory" ref="connectionFactory"/><property name="destination" ref="queueDestination"/><property name="messageListener" ref="queueMessageListener"/></bean><bean id="topicJmsContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer"><property name="connectionFactory" ref="connectionFactory"/><property name="destination" ref="topicDestination"/><property name="messageListener" ref="queueMessageListener"/></bean></beans>
5.编写一个主题模式和队列模式的service和实现,测试方法
5.1 队列的service和实现,测试方法
public interface ProducerQueueService {void sendMessage(String queueName, String msg);void sendMessage(String msg);}
实现:
public class ProducerQueueServiceImpl implements ProducerQueueService {private JmsTemplate jmsTemplate;/*** 向指定队列名发送消息* @param queueName 队列名* @param msg 消息*/public void sendMessage(String queueName, final String msg) {//使用 jmsTemplate 发送消息jmsTemplate.send(queueName, new MessageCreator() {//创建一条消息public Message createMessage(Session session) throws JMSException {TextMessage textMessage = session.createTextMessage(msg);return textMessage;}});System.out.println("向"+queueName+"队列发送消息:"+ msg);}/*** 向默认队列发送消息* @param msg 消息*/public void sendMessage(final String msg) {String queueName = jmsTemplate.getDefaultDestination().toString();//使用 jmsTemplate 发送消息jmsTemplate.send(queueName, new MessageCreator() {//创建一条消息public Message createMessage(Session session) throws JMSException {TextMessage textMessage = session.createTextMessage(msg);return textMessage;}});System.out.println("向"+queueName+"队列发送消息:"+ msg);}public JmsTemplate getJmsTemplate() {return jmsTemplate;}public void setJmsTemplate(JmsTemplate jmsTemplate) {this.jmsTemplate = jmsTemplate;}}
测试方法:
public class AppQueueProducer {public static void main(String[] args) {ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("spring-activemq-producer.xml");ProducerQueueService producerService = applicationContext.getBean(ProducerQueueService.class);for (int i=0;i<100;i++){producerService.sendMessage("spf-queue","queue test"+i);}applicationContext.close();}}
5.1 主题的service和实现,测试方法
service:
public interface ProducerTopicService {void sendMessage(String queueName, String msg);void sendMessage(String msg);}实现:
public class ProducerTopicServiceImpl implements ProducerTopicService {private JmsTemplate topicJmsTemplate;public void sendMessage(String topicName, final String msg) {topicJmsTemplate.setPubSubDomain(true);//使用 jmsTemplate 发送消息topicJmsTemplate.send(topicName, new MessageCreator() {//创建一条消息public Message createMessage(Session session) throws JMSException {TextMessage textMessage = session.createTextMessage(msg);return textMessage;}});System.out.println("向"+topicName+"主题发送消息:"+ msg);}public void sendMessage(final String msg) {topicJmsTemplate.setPubSubDomain(true);String topicName = topicJmsTemplate.getDefaultDestination().toString();//使用 jmsTemplate 发送消息topicJmsTemplate.send(topicName, new MessageCreator() {//创建一条消息public Message createMessage(Session session) throws JMSException {TextMessage textMessage = session.createTextMessage(msg);return textMessage;}});System.out.println("向"+topicName+"主题发送消息:"+ msg);}public void setTopicJmsTemplate(JmsTemplate topicJmsTemplate) {this.topicJmsTemplate = topicJmsTemplate;}public JmsTemplate getTopicJmsTemplate() {return topicJmsTemplate;}}测试方法:
public class AppTopicProducer {public static void main(String[] args) {ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("spring-activemq-producer.xml");ProducerTopicService producerService = applicationContext.getBean(ProducerTopicService.class);for (int i=0;i<100;i++){producerService.sendMessage("spf-topic","topic test"+i);}applicationContext.close();}}6.创建一个监听器
public class MessageListener implements javax.jms.MessageListener {public void onMessage(Message message) {TextMessage textMessage = (TextMessage) message;try {System.out.println("接收消息:"+textMessage.getText());} catch (JMSException e) {e.printStackTrace();}}}
7.写一个类来加载 spring-activemq-customer.xml 配置文件,启动监听器
8.测试队列模式发送 启动两个Customer看效果9.测试主题模式下发送接收消息(启动两个Customer)
相关文章推荐
- 在Spring下集成ActiveMQ
- Spring下集成ActiveMQ推送
- JMS 集成Spring 实现ActiveMQ
- ActiveMQ学习总结(6)——ActiveMQ集成Spring和Log4j实现异步日志
- 在Spring下集成ActiveMQ
- 在Spring下集成ActiveMQ
- Spring集成Activemq使用
- springboot 集成activeMQ实现消息队列和双向队列
- ActiveMQ和spring集成
- 在Spring下集成ActiveMQ
- ActiveMQ学习总结(6)——ActiveMQ集成Spring和Log4j实现异步日志
- ActiveMQ学习总结——(四)Spring集成JMS连接AcitveMQ
- activemq5.14.5+spring-jms3.2.18+maven集成 + jaas权限认证
- spring集成activeMQ
- 从零开始学 Java - Spring 集成 ActiveMQ 配置(二)
- ActiveMQ消息中间件 原理详解 &&附demo实现、以及与springboot集成的demo
- Spring 与 ActiveMq的集成配置使用
- spring boot 集成 activeMQ 传输序列化对象
- 【ActiveMQ】Spring Jms集成ActiveMQ学习记录