资源描述:
《JMS消息服务详解(实用)》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、JMS消息服务Outline§什么是消息服务§为什么使用消息服务§什么是JMS(JavaMessageService)§JMS的通信方式§JMS应用程序开发步骤§JMS应用程序开发实践§其他的JMS特性§Spring与JMS的集成,JMS与MDB的关系§JMS与Task,RMI,CORBA,WEBSERVICE的区别什么是消息服务1.消息服务是支持松耦合分布式通信的对等通信机制。2.消息服务支持软件组件或应用程序之间松耦合分布式通信。3.支持的数据可以是文本,数值,若是Java应用程序之间的通信,数据可以包含对象。4.组件或应用程序之间不一定同时运行。为什么使用
2、消息服务1.松散耦合但高内聚2.避免直接通信3.保证消息传递4.异步通信5.一对多,多对多,多对一通信什么是JMSJMS(Java消息服务)是一组标准的API,能够用于访问多种消息服务器。它试图提供一套标准,统一的接口,这套接口适用于多种不同供应商的消息服务器,在这个意义上,它和JDBC以及JNDI是相似的。那些消息服务器一般都有自己的本机接口,用本机接口可以直接访问消息服务器。但是,使用本机接口的代码不仅可移植性差,而且每当您希望使用另一个消息服务时,都要学习新的API。而使用JMS,你可以使用一样的API访问IBM的MQSeries消息服务和JBossMQ消
3、息服务。准许开发者避免使用各供应商特定的API,这当然是JMS的一大优点。 1.什么是JMS中的消息§消息这个术语在计算机系统中含义非常广泛,它被用来描述不同的操作系统概念,它被用来描述邮件和传真。而在这里,它指的是用于企业应用间的异步通讯。§这里所说的“消息”是指被企业应用而不是人所消费的异步的请求、报告以及事件。消息中包含了重要的用来系统间进行协作的信息。消息中包含了精确的数据格式以描述特定的业务活动,通过应用系统之间的消息交互,使得企业业务过程能够保持一致。2.JMS中的消息的基本结构§2.1消息头§2.2消息属性§2.3消息体2.1消息头消息头包含标
4、准的,必不可少的消息信息,比如每个消息都有个ID,一个优先级,一个时间戳,一个目标。这些信息大部分都在消息发送到目标之前自动设定。消息头可以通过get和set方法存取.形式如:setJMSHeaderName,getJMSHeaderName2.2 消息属性 消息属性是标准的,特定于供应商或特定于应用程序的可选的消息信息,主要作用是帮助消息过滤,消息属性在接收的客户机里是只读的。2.3消息体 消息体是实际的消息内容。JMS支持多种格式的消息体。比如:TextMessage,MapMessage,BytesMessage,StreamMessage,Objec
5、tMessage3.JMS由那些应用部分组成§JMS客户端:用来发送和接收消息的Java语言程序。§非JMS客户端:这些客户端是用消息系统的本地客户端API编写的,而不是JMS。如果应用先于JMS出来之前,那么它可能会既包括JMS客户端,也包括非JMS客户端。§Messages(消息):每个应用定义了用于在客户端之间进行通讯的消息。§JMSProvider(JMS提供者):实现了JMS规范的消息系统,该系统还提供必须的用于管理和控制全方位的功能。§AdministeredObjects(被管理的对象):是预先配置的JMS对象,由系统管理员为使用JMS的客户端创建
6、。4.如何实现JMS客户端程序的跨平台性?§ 由于有很多JMS消息系统,它们的底层实现技术各不相同,比如SunMQ,IBMMQ,BEAMQ,ApacheActiveMQ,那么如何使得JMS客户端针对这些消息系统编程时能够隔离这些产品的变化而具有跨平台特性呢?那就是通过定义被管理的对象来实现。被管理的对象是由管理员通过使用JMS系统提供者的管理工具创建和定制,然后被JMS客户端使用。JMS客户端通过接口来调用这些被管理的对象,从而具备跨平台特性。主要有两个被管理的对象:§ConnectionFactory:这是客户端用来创建同JMS提供者之间的连接的对象。§D
7、estination:这个对象是客户端用来指明消息被发送的目的地以及客户端接收消息的来源。被管理的对象一般被管理员放在JNDI名字空间中,通常在JMS客户端应用的文档中说明它所需要的JMS被管理对象,以及应以何种JNDI名字来提供这些JMS被管理对象。下图是被管理对象的关系: §传统的消息服务一般支持点对点通信和发布/订阅通信两种通信模式中的一种。JMSAPI对两种模式都支持。§1.点对点通信§2.发布/订阅通信§1.点对点通信 2.布/订阅通信 JMS应用程序开发步骤§1.点对点JMS应用程序开发步骤§1.1使用特定于服务器的机制发
8、布目标(队列)。在JBO