文档章节

EJB---->JMS(Java Message Service)和消息驱动bean

小强斋太
 小强斋太
发布于 2016/11/09 20:06
字数 1065
阅读 74
收藏 0

行业解决方案、产品招募中!想赚钱就来传!>>>

Java 消息服务(Java Message Service,简称JMS)是企业级消息传递系统,紧密集成于Jboss Server 平台之中。
企业消息传递系统使得应用程序能够通过消息的交换与其他系统之间进行通信。
消息的传递模型:
JMS 支持两种消息传递模型点对点(point-to-point,简称PTP)和发布/订阅(publish/subscribe,简称pub/sub)。
这两种消息传递模型非常相似,只有以下区别:
PTP 消息传递模型规定了一条消息只能传递给一个接收方。
Pub/sub 消息传递模型允许一条消息传递给多个接收方。
每种模型都通过扩展公用基类来实现。例如,PTP 类javax.jms.Queue 和pub/sub 类javax.jms.Topic 都扩展javax.jms.Destination 类。
1、点对点(PTP) 的消息传递模型,一个应用程序可以向另一个应用程序发送消息。PTP 消息传递应用程序使
用命名队列发送接收消息。队列发送方(生成者)向特定队列发送消息。队列接收方(使用者)从特定队列接收
消息。

一个队列可以关联多个队列发送方和接收方,但一条消息仅传递给一个队列接收方。如果多个队列接收方正在监
听队列上的消息,jboss JMS 将根据“先来者优先”的原则确定由哪个队列接收方接收下一条消息。如果没有队
列接收方在监听队列,消息将保留在队列中,直至队列接收方连接队列为止。

2.发布/订阅消息传递
通过发布/订阅(pub/sub) 消息传递模型,应用程序能够将一条消息发送到多个应用程序。Pub/sub 消息传递应用
程序可通过订阅主题来发送和接收消息。主题发布者(生成器)可向特定主题发送消息。主题订阅者(使用者)
从特定主题获取消息。
与PTP 消息传递模型不同,pub/sub 消息传递模型允许多个主题订阅者接收同一条消息。JMS 一直保留消息,
直至所有主题订阅者都收到消息为止。
Message-Driven Bean 由EJB 容器进行管理,具有一般的JMS 接收者所不具有的优点,如对于一个
Message-driven Bean,容器可创建多个实例来处理大量的并发消息,而一般的JMS 使用者(consumer)开发时则必
须对此进行处理才能获得类似的功能。同时Message-Driven Bean 可取得EJB 所能获得的标准服务,如容器管理
事务等服务。
消息驱动Bean(MDB)是设计用来专门处理基于消息请求的组件。MDB 负责处理消息,而EJB 容器则负责处理服务(事务、安全、资源、并发、消息确认,等等),使bean 开发者把精力集中在处理消息的业务逻辑上。如果你不使用MDB,则必须编写一部分这些服务。MDB 像一个没有local 和remote 接口的无状态Session Bean,它和无状态Session Bean 一样也使用了实例池机制,容器可以为它创建大量的实例,用来并发处理成百上千个JMS 消息。正因为MDB 具有处理大量并发消息的能力,所以非常适合应用在一些消息网关产品。一个MDB 通常要实现MessageListener 接口,该接口定义了onMessage()方法。Bean 通过它来处理收到的JMS 消息。
package javax.jms;
public interface MessageListener {
public void onMessage(Message message);
}
当容器检测到bean 守候的管道有消息到达时,容器调用onMessage()方法,将消息作为参数传入MDB。MDB 在
onMessage()中决定如何处理该消息。你可以使用注释指定MDB 监听哪一个目标地址(Destination)。当MDB 部署
时,容器将读取其中的配置信息。
如果一个业务执行的时间很长,而执行结果无需实时向用户反馈时,也很适合使用MDB。如订单成功后给用户
发送一封电子邮件或发送一条短信等。

 

上一篇: Oracle---->Join
下一篇: Centos 7配置LAMP
小强斋太
粉丝 0
博文 181
码字总数 0
作品 0
广州
私信 提问
加载中
请先登录后再评论。
Netty那点事(三)Channel与Pipeline

Channel是理解和使用Netty的核心。Channel的涉及内容较多,这里我使用由浅入深的介绍方法。在这篇文章中,我们主要介绍Channel部分中Pipeline实现机制。为了避免枯燥,借用一下《盗梦空间》的...

黄亿华
2013/11/24
2W
22
访问安全控制解决方案

本文是《轻量级 Java Web 框架架构设计》的系列博文。 今天想和大家简单的分享一下,在 Smart 中是如何做到访问安全控制的。也就是说,当没有登录或 Session 过期时所做的操作,会自动退回到...

黄勇
2013/11/03
3.4K
6
我的架构演化笔记 功能1: 基本的用户注册

“咚咚”,一阵急促的敲门声, 我从睡梦中惊醒,我靠,这才几点,谁这么早, 开门一看,原来我的小表弟放暑假了,来南京玩,顺便说跟我后面学习一个网站是怎么做出来的。 于是有了下面的一段...

强子哥哥
2014/05/31
976
3
TDD的测试框架--Machine.Specification

Machine.Specification 是一个 TDD 测试驱动开发的测试框架,简化了测试,无需关心语言本身特性。 Machine.Specifications 带来的好处是不需要在代码里有注释,但同时阅读代码的人可以一目了...

匿名
2013/01/22
1.1K
0
mvc框架--Razor

Razor 是一个轻巧而优雅的servlet mvc框架 # 又一个轮子? no,写就她是为了证实我个人的某些想法,并在这个过程中练练手,这两种冲动碰撞在一起,自然而然地产生了Razor # Razor的现在和未来...

dtubest
2013/01/25
3K
0

没有更多内容

加载失败,请刷新页面

加载更多

数据库高频面试点,事务/乐观锁/悲观锁/CAS/MySQL存储引擎

事务的ACID特性是什么? 原子性: 事务是最小的执行单位,不允许分割。事务的原子性确保动作要么全部完成,要么完全不起作用; 一致性: 执行事务前后,数据保持一致,多个事务对同一个数据读...

osc_45536bvu
59分钟前
16
0
大数据BI软件助力企业数字化转型

当下,「新基建」势头正盛,随着“新基建”成为热议话题,数字化也随之成为企业面临的新机遇和新挑战。新基建的核心就是数据,数据是数字经济和企业数字化转型的生产要素和发展动力。 再看看...

osc_0boqdoe2
今天
7
0
凯旋创投来志刚:基因治疗新时代,大戏刚刚开始

  2017 年,全球第一个基因治疗方法 CAR-T 细胞药物 Kymriah 获得 FDA 上市批准,从此掀起了基因治疗的热潮。随着相关技术和政策的不断成熟,基因治疗市场也随之扩大。根据德勤发布的《引领...

osc_k3vwonkw
今天
10
0
LightningChart.NET使用两个BarSeries创建简单的2D图表

本教程介绍了如何使用两个BarSeries创建简单的2D图表。 BarSeries将数据值表示为矩形条,并且可以用于以非常清晰的方式可视化数据之间的差异和方差。 在本教程中,BarSeries用于表示两年期间...

roffey
今天
0
0
Mybatis trim 标签的 2 个妙用!

云栖号资讯:【点击查看更多行业资讯】 在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! mybatis的trim标签一般用于去除sql语句中多余的and关键字,逗号,或者给sql语句前拼...

osc_x03qsedc
今天
10
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部