JMS——Spring+ActiveMQ
2013-03-22 15:37
411 查看
JMS即Java消息服务(Java
Message Service),是一种提供应用程序之间信息交互的规范。其类似于JDBC,JDBC是Java官方提供的用于访问不同关系型数据库的API,需要不同的数据库厂商实现它;JMS也提供了API,许多第三方Provider都支持它,这里要介绍的ActiveMQ就是由Apache出品的消息总线。接下来介绍一下JMS的主要接口:
1.ConnectionFactory/Connection 接口:ConnectionFactory(连接工厂)用于提供Connection,其类似于JDBC的Connection。JDBC的Connection适用于连接数据库,而JMS的Connection是用于连接第三方Provider,这里即ActiveMQ。
2.Session
接口:表示一次会话,也可以说是一个线程。
3.Destination
接口:表示消息要发送到的目标;可以是一个主题(Topic)或者一个队列(Queue)。打个比方,就好比是一个消息的通道,发送消息的人需要把消息发送到这个通道,阅读消息的人需要从这个通道读取消息。他是通过Session创建,比如Destination destination = session.createQueue("MyQueue");
4.MessageProducer
接口:表示发送消息的人,也是由Session创建的,需要把消息目标传入,如MessageProducer producer = session.createProducer(destination);
5.MessageConsumer
接口:表示接收消息的人,由Session创建,MessageConsumer consumer
= session.createProducer(destination);
6.Message
接口:表示所要发的消息,也是由Session创建。
了解了JMS的主要接口,接下来要用到ActionMQ。官方下载地址:http://activemq.apache.org/activemq-580-release.html,解压以后直接运行apache-activemq-5.8.0\bin\activemq.bat,你可以通过http://localhost:8161/admin/queues.jsp查看自己已经创建的队列通道和发送消息。刚开始登录的用户名和密码为admin。需要用到的springjar包不一一列举,还需要spring-jms.jar,还有ActiveMQ的jar包activemq-all-5.8.0.jar,这个jar包在下载的activemq包中有。
下面是Spring的配置文件applicationContext.xml:
下面是用于发送信息的MessageSender.java:
下面是用于接收消息的MessageReciver.java:
Message Service),是一种提供应用程序之间信息交互的规范。其类似于JDBC,JDBC是Java官方提供的用于访问不同关系型数据库的API,需要不同的数据库厂商实现它;JMS也提供了API,许多第三方Provider都支持它,这里要介绍的ActiveMQ就是由Apache出品的消息总线。接下来介绍一下JMS的主要接口:
1.ConnectionFactory/Connection 接口:ConnectionFactory(连接工厂)用于提供Connection,其类似于JDBC的Connection。JDBC的Connection适用于连接数据库,而JMS的Connection是用于连接第三方Provider,这里即ActiveMQ。
2.Session
接口:表示一次会话,也可以说是一个线程。
3.Destination
接口:表示消息要发送到的目标;可以是一个主题(Topic)或者一个队列(Queue)。打个比方,就好比是一个消息的通道,发送消息的人需要把消息发送到这个通道,阅读消息的人需要从这个通道读取消息。他是通过Session创建,比如Destination destination = session.createQueue("MyQueue");
4.MessageProducer
接口:表示发送消息的人,也是由Session创建的,需要把消息目标传入,如MessageProducer producer = session.createProducer(destination);
5.MessageConsumer
接口:表示接收消息的人,由Session创建,MessageConsumer consumer
= session.createProducer(destination);
6.Message
接口:表示所要发的消息,也是由Session创建。
了解了JMS的主要接口,接下来要用到ActionMQ。官方下载地址:http://activemq.apache.org/activemq-580-release.html,解压以后直接运行apache-activemq-5.8.0\bin\activemq.bat,你可以通过http://localhost:8161/admin/queues.jsp查看自己已经创建的队列通道和发送消息。刚开始登录的用户名和密码为admin。需要用到的springjar包不一一列举,还需要spring-jms.jar,还有ActiveMQ的jar包activemq-all-5.8.0.jar,这个jar包在下载的activemq包中有。
下面是Spring的配置文件applicationContext.xml:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd"> <beans> <bean id="connectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory"> <property name="brokerURL" value="tcp://localhost:61616"/> </bean> <!-- Spring提供的JMS模板,封装了JMS的主要对象和方法 --> <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate"> <property name="connectionFactory" ref="connectionFactory"/> </bean> <!-- ActiveMQQueue实现的JMS的接口 --> <bean id="destination" class="org.apache.activemq.command.ActiveMQQueue"> <!-- MyQueue是给消息通道取的名字,通过这个消息通道收发消息 --> <constructor-arg index="0" value="MyQueue"/> </bean> </beans>
下面是用于发送信息的MessageSender.java:
package com.xxx.jms; import javax.jms.Destination; import javax.jms.JMSException; import javax.jms.Message; import javax.jms.Session; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import org.springframework.jms.core.JmsTemplate; import org.springframework.jms.core.MessageCreator; public class MessageSender extends Thread { public static void main(String args[]) throws Exception { ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml"); JmsTemplate jmsTemplate = (JmsTemplate) context.getBean("jmsTemplate"); Destination destination = (Destination) context.getBean("destination"); jmsTemplate.send(destination, new MessageCreator() { public Message createMessage(Session session) throws JMSException { return session.createTextMessage("Hello ActiveMQ!"); } }); } }
下面是用于接收消息的MessageReciver.java:
package com.xxx.jms; import javax.jms.Destination; import javax.jms.TextMessage; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import org.springframework.jms.core.JmsTemplate; public class MessageReciver { public static void main(String args[]) throws Exception { ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml"); JmsTemplate jmsTemplate = (JmsTemplate) context.getBean("jmsTemplate"); Destination destination = (Destination) context.getBean("destination"); TextMessage msg = (TextMessage)jmsTemplate.receive(destination); System.out.println(msg.getText()); } }
相关文章推荐
- Spring整合ActiveMQ:spring+JMS+ActiveMQ+Tomcat
- ActiveMQ JMS non-Spring Snippet
- Spring + ActiveMQ兑现jms发送消息
- 基于Spring+JMS+ActiveMQ+Tomcat
- jms activeMQ与spring集成进阶篇
- activemq jms spring 发送调优
- Spring + ActiveMQ兑现jms发送消息
- spring+ActiveMQ+JMS+线程池实现简单的分布式,多线程,多任务的异步任务处理系统
- JMS(十一): ActiveMQ + Spring 之两种监听器的实现方案。
- spring boot jms activemq
- Spring+ActiveMQ+Mysql 配置JMS
- jms+spring+activemq配置(发送和接收消息)
- jms+spring+activemq配置(发送和接收消息)
- Spring+JMS+使用JMS+ActiveMQ中间件+实现简单聊天功能的小例子
- ActiveMQ JMS Spring的一个实例
- Spring + ActiveMQ实现jms发送消息
- Spring全家桶(1):Spring JMS + ActiveMQ起步
- Spring+JMS+ActiveMQ+Tomcat实现消息服务
- 学习activemq(2)Spring boot整合activemq jms
- jms activeMQ与spring集成进阶篇(转载)