文档章节

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

小强斋太
 小强斋太
发布于 2016/11/09 20:06
字数 1065
阅读 13
收藏 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。如订单成功后给用户
发送一封电子邮件或发送一条短信等。

 

本文转载自:http://www.cnblogs.com/xqzt/archive/2012/05/15/5637396.html

共有 人打赏支持
小强斋太
粉丝 0
博文 181
码字总数 0
作品 0
广州
CDI(Weld)整合整合JavaEE环境组件资源

除了基础部分和高级部分,CDI的第三个主题是整合。 CDI还设计了通过SPI提供集成点到Java EE平台的协同工作的平台之外的技术[在Java EE 6发布后,各种各样的Java EE平台扩展(构建在CDI扩展SPI之...

Zhao-Qian
2014/05/18
0
2
Websphere Application Server(版本:8.0.0.3)JMS配置(m...

总线配置 服务集成>总线 创建总线,创建时去除“总线安全性”选项,避免客户端请求时的安全拦截; 总线 > mybus(总线名称) > 总线成员 建完后,添加总线成员,选择“服务器”下拉项中的当前...

wolf_su
2013/05/17
0
0
操作ibatis,struts,spring的整合

处理mybatis,struts,spring框架的整合作为学习java资料 步骤: 一.添加Spring、Struts框架对web.xml文件的修改 1. 添加Spring框架 2. 在web.xml中引入Spring配置文件(注意:applicationCont...

xinlll
2012/10/25
0
1
J2EE中一些常用的名词【简】

web容器:给处于其中的应用程序组件(JSP,SERVLET)提供一个环境,使JSP,SERVLET直接更容器中的环境变量接口交互,不必关注其它系统问题。主要有WEB服务器来实现。例如:TOMCAT,WEBLOGIC,W...

anlve
06/18
0
0
Spring JMSTemplate 与 JMS 原生API比较

博客分类: JMS Spring 2.x JMSUtil与Spring JmsTemplate的对比 Author:信仰 Date:2012-4-20 未完待续,截止日期2012-4-20 从以下几方面比较JMSUtil和Spring JmsTemplate l 对JNDI的支持 ...

thinkyoung
2014/12/12
0
0

没有更多内容

加载失败,请刷新页面

加载更多

搬瓦工镜像站bwh1.net被DNS污染,国内打不开搬瓦工官网

今天下午(2018年10月17日),继搬瓦工主域名bandwagonhost.com被污染后,这个国内的镜像地址bwh1.net也被墙了。那么目前应该怎么访问搬瓦工官网呢? 消息来源:搬瓦工优惠网->搬瓦工镜像站b...

flyzy2005
今天
1
0
SpringBoot自动配置

本篇介绍下,如何通过springboot的自动配置,将公司项目内的依赖jar,不需要扫描路径,依赖jar的情况下,就能将jar内配置了@configuration注解的类,创建到IOC里面 介绍下开发环境 JDK版本1.8 spr...

贺小五
今天
3
0
命令行新建Maven多项目

参考地址 # DgroupId 可以理解为包名# DartifactId 可以理解为项目名mvn archetype:generate -DgroupId=cn.modfun -DartifactId=scaffold -DarchetypeArtifactId=maven-archetype-quickst......

阿白
今天
1
0
OSChina 周四乱弹 —— 上帝对我单身年限的惩罚越来越长了

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @达尔文:分享张卫健的单曲《身体健康》 《身体健康》- 张卫健 手机党少年们想听歌,请使劲儿戳(这里) 昨天是重阳节咯, 可惜小小编辑总是晚...

小小编辑
今天
12
1
django rest framework 外键序列化方法与问题总结

django rest framework 外键序列化方法与问题总结 当借口中需要出现一对多关系的时候,我们可以用rest_framwork的序列化功能来处理,代码如下. # models.pyfrom django.db import modelscl...

_Change_
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部