消息系统PPT.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
消息系统PPT

消息系统 消息驱动bean EJB系统设计时的一些考虑 EJB设计模式改进;消息是什么 消息是在软件组件或应用程序间进行通信的一种方法。消息使得分布式通信成为松耦合的,即一个组件向目的地发送消息后,接收者可以从目的地得到消息,发送者和接收者不必为了通信而同时出现。;消息系统:消息系统就是个peer-to-peer的工具。一个消息客户端可以从任何一个客户端接收消息,也可以向任何一个客户端发送消息。每个客户端都连接到消息代理,这个代理提供生成、发送和接收消息的便利工具。;Messaging Client;对于一个企业信息系统来讲,在分布式系统的应用程序之间提供传递消息的服务。消息传递服务是一个软件,它对以一种可靠的、异步的、松散耦合的、语言无关的及平台无关的方式在分布式应用程序之间传递消息提供支持。;点到点消息模式;发布/订阅消息传递:发布/订阅消息???统支持一个事件驱动模型,消息产生者和使用者都参与消息的传递。产生者发布事件,而使用者订阅感兴趣的事件,并使用事件。产生者将消息和一个特定的主题(Topic)连在一起,消息系统根据使用者注册的兴趣,将消息传给使用者。 ;pub/sub消息模式;8. 消息驱动bean-消息系统;基本概念:在JAVA技术中,处理异步消息的能力是通过JMS来实现的。JMS是一组Java API ,它定义了消息传递客户如何以一种标准的方式与底层的消息服务提供商进行交互。同时,也提供了一个底层的消息传递服务实现的一个接口,它将JMS服务提供给客户。;同步:客户端通过receive方法显示地从目的地得到消息。 receive方法可以阻塞到直到一条消息的到来; 异步:无论消息何时到达目的地,JMS供应者通过侦听者onMessage方法来分发消息。;JMS消息构成;8. 消息驱动bean-消息系统;8. 消息驱动bean-消息系统;一个典型的JMS客户端由下面的几个基本步骤来创建: 创建一个到消息系统提供者的连接 (Connection) 。 创建一个Session,用于接收和发送消息。 创建MessageProducer和MessageConsumer 来创建和接收消息。 ;基本概念;消息驱动Bean的工作流程;消息驱动bean概述;消息驱动Bean接口 所有消息驱动Bean必须实现MessageDrivenBean接口。容器通过调用setMessageDrivenContext方法使得一个消息驱动bean实例与由容器维护的上下文联系起来。即消息驱动bean实例将它的上下文作为其状态的一部分。;Javax.jms.MessageListener接口 所有消息驱动Bean必须实现Javax.jms.MessageListener接口。当有一个消息到达,需要bean去服务时,容器会调用bean的onMessage方法。该方法包含了处理消息的商业逻辑,它只有一个参数,即引入的消息。 在EJB规范中,只有消息驱动bean可以异步地接收消息,会话bean和实体bean不允许成为JMS MessageListeners。;消息驱动Bean的上下文接口 容器为消息驱动Bean实例提供了MessageDrivenContext。这使得消息驱动bean实例可以访问由容器维护的实例上下文。 MessageDrivenContext接口含有如下方法:;8. 消息驱动bean-消息驱动bean;8. 消息驱动bean-消息驱动bean;ejbCreate()方法:Bean提供者必须提供一个无参数的ejbCreate()方法,用于在EJB服务器对Bean进行设置。Bean实例可以在ejbCreate()方法中取得需要的资源。 ejbRemove()方法:在把消息驱动Bean从任何存储上删除时调用,并进行清除操作和垃圾收集。必须在ejbRemove()方法中释放所有Bean实例用到的资源。;消息应答:消息驱动Bean不使用JMS API进行消息应答,而是由容器自动进行处理。如果消息驱动Bean使用容器管理的事务划分,则消息应答就作为事务提交的一部分进行处理;否则就由容器进行应答。 处理异常:消息驱动Bean的onMessage方法不能抛出应用程序异常或者java.rmi.Remote Exception,而是和其他JMS消息侦听器一样,抛出RuntimeException。;8. 消息驱动bean-消息驱动bean;当客户端向一个目的地发送消息,而对于这个目的地来说消息驱动Bean是消费者时,容器选择它的一个ready状态的实例,并调用实例的onMessage方法。 当容器不再需要实例(通常发生在容器想减少在就绪池中的实例数量)时,容器调用实例上的ejbRemove()方法。;消息驱动Bean 小结;消息驱

文档评论(0)

djdjix + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档