首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

Spring调整JMS

2012-10-11 
Spring整合JMS今天看书看了下JMS,初步有了个了解,具体的JMS知识还需要进一步的深入学习。J2EE中,JMS(Java M

Spring整合JMS
今天看书看了下JMS,初步有了个了解,具体的JMS知识还需要进一步的深入学习。

J2EE中,JMS(Java Message System)提供了一种异步处理机制的实现。JMS通过异步的、非阻塞的消息传递,将消息的生产者和使用者松散的联系在一起。对于使用者,它无所谓是谁产生了消息或者是在何时产生的。这就能够建立一种动态的、灵活的可靠的系统。所谓可靠,因为JMS将每个消息都保存起来,只有确保本消息处理后才会完全放弃。否则,将会反复提交处理。这种可靠的机制使得JMS能够成功的在证券、银行系统中得到广泛应用。

JMS中的消息类型有两种:Topic和Queue。Topic的操作是使用发布/订阅(publish/subscribe)的方式;Queue的操作是点对点(ponit to point)的方式。

·publish/subscribe:发布者(publisher)发布消息到Topic,订阅者(subsribe)从Topic订阅消息,订阅者的数量是不受限制的。

· ponit to point:点对点传输消息,建立在消息队列Queue的基础上,每个消息使用者只对应一个消息队列,不像publish/subscribe那样可以有很多消息使用者。

JMS在消息到达消息使用者,有两种——同步和异步。

·同步是指消息使用者明确地主动地调用从Queue或Topic中得到消息,一直进行循环直至一个消息到达,或者也可以设定超时时间。很明显这个方法是比较耗费CPU资源的。

·异步接受是指消息到达时,主动通知消息使用者,消息使用者可以实现message listener接口。这样每当消息到达时,JMS provider 会通过调用这个listener的onMessage方法来传输这个消息。

参考spring的资料,写了个Spring+JMS的例子。
1.建立工程spring_jms,导入工程相应的包,所用的包都是ActiveMQ自带的,在apache-activemq-5.2.0\lib\optional下可以找到。


2.applicationContext.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-2.5.xsd    http://www.springframework.org/schema/context    http://www.springframework.org/schema/context/spring-context-2.5.xsd">    <!-- 配置JMS连接工厂 -->    <bean id="connectionFactory" value="tcp://localhost:61616"/>    </bean>    <!-- 配置JMS模版 -->    <bean id="jmsTemplate" ref="connectionFactory"/>    </bean>    <!-- 发送消息的目的地(一个队列) -->    <bean id="destination" value="HelloWorldQueue"/>    </bean></beans>


3.消息发送程序HelloWorldSender
package com.springjms;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;import org.springframework.jms.core.JmsTemplate;import org.springframework.jms.core.MessageCreator;import javax.jms.Destination;import javax.jms.JMSException;import javax.jms.Message;import javax.jms.Session;/** *  * @author Wind * */public class HelloWorldSender {    public static void main(String[] args) {        ApplicationContext ctx = new ClassPathXmlApplicationContext("/applicationContext.xml");        JmsTemplate template = (JmsTemplate) ctx.getBean("jmsTemplate");        Destination destination = (Destination) ctx.getBean("destination");        template.send(destination, new MessageCreator() {            public Message createMessage(Session session) throws JMSException {            return session.createTextMessage("Hello World,ActiveMQ Spring JMS Message!");            }        });        System.out.println("JMS Message Sent");    }}


4.消息接收程序HelloWorldReceiver
package com.springjms;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;import org.springframework.jms.core.JmsTemplate;import javax.jms.Destination;import javax.jms.JMSException;import javax.jms.TextMessage;/** *  * @author Wind * */public class HelloWorldReceiver {    public static void main(String[] args) throws JMSException {        ApplicationContext ctx = new ClassPathXmlApplicationContext("/applicationContext.xml");        JmsTemplate template = (JmsTemplate) ctx.getBean("jmsTemplate");        Destination destination = (Destination) ctx.getBean("destination");        while (true) {            TextMessage txtmsg = (TextMessage) template.receive(destination);            if (null != txtmsg){             System.out.println("Received Message: " + txtmsg.getText());            }else{                break;            }        }    }}


5.启动ActiveMQ,先运行发送者HelloWorldSender,然后运行HelloWorldSenderReceiver,控制台输出如下:
Received Message: Hello World,ActiveMQ Spring JMS Message!

6.继续运行HelloWorldSender发现,接收端接收一条消息后没有退出程序,而是继续等待,一旦有消息发送过来,就获取到,然后输出!

7.哈哈,这个也很简单,继续看书,接下来弄个JMS本地事务的例子。

热点排行