1)什么是java消息服务

java消息服务(Java Message Service, JMS)是一个允许应用创建、发送、接收和读取消息的Java API

2)JMS消息传送模型

JMS应用由以下部分组成
  JMS提供者:是一个实现JMS接口的消息传送系统,提供管理和控制特性
  JMS客户端:是用Java编程语言编写的程序和组件,可以生成(生产)和使用(消费)消息
  消息:是在JMS客户端之间传递信息的对象
  受管理对象:是为客户端配置的JMS对象,有两类JMS受管理
  对象:目的工厂(destination) 和 连接工厂(connection factory)

发送方式
模型一  点对点(point to point)
  * 每个消息只有一个消费者(即使用方)
  * 接收者可以获取消息,而不论客户端发送消息时接收者是否在运行
  所以说如果你发送一个每一个消息都必须由一个消费者成功地处理,就可以使用PTP消息传送

模型二  发布/订阅消息传送方式
        * 每个消息可以有多个消费者
  * 对于订阅一个主题的客户端,只有这个客户端创建一个订阅之后才能使用锁发送的消息,消费者必须保持活动状态才能使用消息(对于这种情况相对与上一种要复杂一点。只有创建了共享订阅才能被多个订阅者订阅)
  所以如果消息可以由任意多个消费者(或者没有任何消费者)处理,就可以使用发布/订阅消息传送方式

消息的接收
  消息产品本质上市异步的:在消息的生成和使用之间并没有时间依赖关系,不过JMS还是提供了两种方案
  (1)同步:消息者通过调用receive方法,显式地从目的地获取消息。receive方法会阻塞,直到消息到达,或者如皋消息未在指定的时限内到达则会超时。
  (2)异步:应用客户端或Java SE客户端可以向消费者注册一个消息监听器(messagelistener).消息监听器类似于事件监听器。一旦有消息到达目的地,JMS
  提供者就通过调用这个监听器onMessage方法传送消息,这个方法会处理消息的内容。在一个Java EE应用中,消息驱动bean会作为消息监听器(它也有一个onMessage方法),不过客户端不需要消费者注册这个监听器。

上图

 

 

 

 

 

 

Logo

CSDN联合极客时间,共同打造面向开发者的精品内容学习社区,助力成长!

更多推荐