Java学习(11) -- JMS
1)什么是java消息服务java消息服务(Java Message Service, JMS)是一个允许应用创建、发送、接收和读取消息的Java API2)JMS消息传送模型JMS应用由以下部分组成 JMS提供者:是一个实现JMS接口的消息传送系统,提供管理和控制特性 JMS客户端:是用Java编程语言编写的程序和组件,可以生成(生产)和使用(消费)消息 消息:是在JMS...
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方法),不过客户端不需要消费者注册这个监听器。
上图
更多推荐
所有评论(0)