基于JMS的数据清分

上传人:876****10 文档编号:142026931 上传时间:2020-08-15 格式:DOC 页数:11 大小:181KB
返回 下载 相关 举报
基于JMS的数据清分_第1页
第1页 / 共11页
基于JMS的数据清分_第2页
第2页 / 共11页
基于JMS的数据清分_第3页
第3页 / 共11页
基于JMS的数据清分_第4页
第4页 / 共11页
基于JMS的数据清分_第5页
第5页 / 共11页
点击查看更多>>
资源描述

《基于JMS的数据清分》由会员分享,可在线阅读,更多相关《基于JMS的数据清分(11页珍藏版)》请在金锄头文库上搜索。

1、基于JMS的数据清分 作者: 日期:基于JMS的数据清分1 JMS概述JMS是一个标准的应用编程接口(API),用来建立厂商中立的异步通信机制。从这个意义上说,JMS类似于JDBC和JNDI,例如就JDBC来说,它要求有一个底层的数据库提供者,JMS则要求有一个支持JMS标准的底层异步通信中间件提供者,一般称为面向消息的中间件(Message-Oriented Middleware,MOM)。 MOM是一种支持应用程序通过交换消息实现异步通信的技术。在某种程度上,异步通信有点象是人们通过email进行通信;类似地,同步通信的程序就象是人们通过电话进行通信。在异步通信过程中,程序的结合方式是宽松

2、的,换句话说,异步通信的程序并不直接相互联系,而是通过称为队列(Queue)或主题(Topic)的虚拟通道联系。JMS有两种通信方式:第一种是端对端通信(Point-to-Point,P2P)方式,第二种是出版/订阅(Publish/Subscribe,Pub/Sub)方式。1.1 P2P方式P2P消息传递又可以按照推(Push)和拉(Pull)两种方式运作。在P2P拉方式中,程序通过称为队列的虚拟通道通信:在通信会话的发送方,发送程序把一个消息放入队列,在接收方,接收程序定期扫描队列,寻找它希望接收和处理的消息。和推方式相比,拉方式的消息传递效率较低,因为它需要周而复始地检查消息是否到达,这

3、个过程会消耗一定的资源。另外必须注意的一点是,当接收方发现一个需要处理的消息时,它就会提取消息,从效果上看等于从队列删除了消息。 因此,即使有多个接收程序在处理同一个队列,对于某一特定的消息来说,总是只有一个接收者。JMS程序可以使用多个队列,每一个队列可以由多个程序处理,但是只有一个程序才会收到某个特定的消息。 在P2P推方式的消息传递中,发送程序的工作原理也一样,它把消息发送到队列,但接收程序的工作原理有所不同。接收程序实现了一个Listener接口,包括实现了该接口中的onMessage回调方法,在J2EE环境中监听队列接收消息的任务交给了容器,每当一个新的消息达到队列,容器就调用onM

4、essage方法,将消息作为参数传递给onMessage方法。 P2P通信最重要的特点(不管是推还是拉)是:每一个消息总是只由一个程序接收。一般而言,P2P程序在通信过程中参与的活动较多,例如,发送程序可以向接收程序指出应答消息应当放入哪一个队列,它还可以要求返回一个确认或报告消息。1.2 Pub/Sub方式在Pub/Sub通信方式中,程序之间通过一个主题(Topic)实现通信。在消息发送方,生产消息的程序向主题发送消息;在接收方,消息的消费程序向感兴趣的主题订阅消息。当一个消息到达主题,所有向该主题订阅的消费程序都会通过onMessage方法的参数收到消息。这是一种推式的消息传递机制。可以设

5、想,会有一个以上的消费程序收到同一消息的副本。相比之下,程序在Pub/Sub通信过程中参与的活动较少,当生产者程序向某个特定的队列发送消息,它不知道到底会有多少程序接收到该消息(可能有多个,可能没有)。2 数据清分2.1 清分模式清分程序从总公司把数据按各分公司分类,分别发送给各个分公司,分公司接收处理数据后反馈给总公司,如下图:总公司分公司A分公司B分公司N在数据清分中,对于某一笔数据来说,只发送给某个地方,也就是说一个消息只有一个消费者;从这个意义上来说P2P方式更适合做数据清分。如果数据是单向的传输,即只从总公司发送给分公司,那么只需要每个公司一个队列就可以实现,总公司配置“反馈队列”,

6、分公司配置“消息队列”,如下图:总公司分公司反馈队列消息队列如果数据是双向的,即分公司也要发送数据给总公司,那么每个公司都需要配置两个队列,如下图:总公司分公司反馈队列消息队列消息队列反馈队列我们的实现的程序支持双向方式,我们称之为ssjms,后面文档中的部署例子是双向方式的。2.2 ssjms介绍ssjms实现了双向消息发送机制,程序包中提供了发送消息的API,消息的接受采用MDB(消息EJB)来自动处理,下图是文件的结构。src是源代码目录,resource是ejb的配置文件,test是发送消息的测试例子。2.2.1 发送消息com.sinosoft.jms.core.Producer类提

7、供了发送消息方法sendMessage。以下是发送消息的例子,在test目录中可以找到。package com.sinosoft.jms.core.examples;import java.util.Properties;import javax.jms.JMSException;import javax.naming.NamingException;import com.sinosoft.jms.core.Log;import com.sinosoft.jms.core.MessageBody;import com.sinosoft.jms.core.Producer;public clas

8、s ProducerTest /* * param args * throws JMSException * throws NamingException */public static void main(String args) throws NamingException, JMSException Producer producer = new Producer(t3:/localhost:5050,t3:/localhost:6060);MessageBody body = new MessageBody();body.setData(hello world!);Properties

9、 properties = new Properties();properties.setProperty(BizType, Policy);properties.setProperty(PK, PDAA200800000000000001);body.setProperties(properties);String id = producer.sendMessage(body);Log.info(JMSMessageID = +id);下面讲下发送消息的步骤13:1、 创建Producer的对象Producer producer = new Producer(t3:/localhost:50

10、50,t3:/localhost:6060);构造函数的入参含义如下:/* * 消息生产者 * param fromServerURL 发送端服务器URL * param toServerURL 接收端服务器URL */public Producer(String fromServerURL, String toServerURL)2、 创建消息体MessageBodyMessageBody body = new MessageBody();消息体可以通过setData和setProperties方法来设置消息数据,3、 把消息发送出去String id = producer.sendMess

11、age(body);调用Producer.sendMessage方法,把消息发送出去。2.2.2 接收消息我们采用了MDB自动接收消息,分成两种MDB:接收消息EJB和接收反馈EJB;由于我们是双向的方式,因此需要实现两对EJB(4个EJB),分别是:分公司接收消息EJB总公司接收反馈EJB,总公司接收消息EJB分公司接收反馈EJB。2.2.2.1 接收消息EJB新编写类,继承RequestConsumerBean类,覆盖方法receiveMessage:public MessageBody receiveMessage(MessageBody messageBody);入参是接收到的消息,返

12、回需要反馈的消息。META-INF/ejb-jar.xml: RequestConsumerBean com.sinosoft.jms.mdb.RequestConsumerBean Container javax.jms.Queue 其中ejb-class内容需要根据继承的类名修改。2.2.2.2 接收反馈EJB新编写类,继承ResponseConsumerBean类,覆盖方法receiveMessage:public MessageBody receiveMessage(MessageBody messageBody);入参是接收到的反馈消息,返回null。META-INF/ejb-jar.xml: ResponseConsumerBean com.sinosoft.jms.mdb.ResponseConsumerBean Container javax.jms.Queue/destination-typ

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号