- 浏览: 705850 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (272)
- Struts1.x (7)
- 事务 (2)
- Hibernate (11)
- 数据库 (14)
- JavaScript&Ajax (43)
- JSP&Servlet (2)
- Flex (1)
- 其它 (9)
- Java (22)
- 框架集成 (1)
- WebService (3)
- Tomcat (3)
- 加密和安全登录 (13)
- 基于原型的JavaScript (0)
- JavaDoc和Java编码规范 (3)
- CAS (1)
- 加密 (1)
- Axis2 (10)
- Ext2.x (3)
- SSH整合 (2)
- Ext (0)
- 正则表达式 (1)
- 设计模式 (4)
- 对象序列化技术 (3)
- CVS (2)
- Struts2 (6)
- Spring 2.x (7)
- Spring Security (2)
- Java 课程 (20)
- 程序员之死 (1)
- 软件测试 (6)
- UML (5)
- NetBeans (1)
- cxf (1)
- JMS (13)
- 设计 (5)
- ibatis2.x (3)
- Oracle (1)
- WebSphere (7)
- 概要设计 (1)
- DB2 (10)
- PowerDesigner (0)
- 软件工程 (5)
- rose (1)
- EA (1)
- LDAP (7)
- Portal&Portlet (3)
- MQ (10)
- ESB (4)
- EJB (2)
- JBoss (2)
最新评论
-
typeRos:
只有配置文件,没有代码么大神
Spring实现IBMMQ的JMS消息发布/订阅模式 -
panamera:
如果ActiveMQ服务器没有启动,这个时候消息生产者使用Jm ...
Spring JMSTemplate 与 JMS 原生API比较 -
lian819:
顶1楼, 引用文件, 配置属性, 太方便了
EXTJS 同步和异步请求 -
wilhard:
说得清楚明白
<%@ include file=""%>与<jsp:include page=""/>区别 -
刘琛颖:
总结的很好。受益了
javascript 父窗口(父页面)— 子窗口 (子页面)互相调用的方法
EJB3.0中MessageDrivenBean:
1.java消息驱动bean属于Java消息服务(Java Message Service,简称JMS)。
2.JMS是用于访问企业消息系统的开发商中心的API。企业消息系统可以协助应用软件通过网络进行消息交互。
3.JMS的编程过程简单概括为:应用程序A-->(消息)-->Jboss JMS-->(消息)-->应用程序B。应用程序A和应用程序B没有直接的代码关联,两者实现了解耦。消息传递系统的中心就是消息。
消息驱动Bean(MDB)是设计用来专门处理基于消息请求的组件,它和无状态Session Bean一样也使用了实例池技术,容器可以使用一定数量的bean实例并发处理成百上千个JMS消息。正因为MDB具有处理大量并发消息的能力,所以非常适合应用在一些消息网关产品。如果一个业务执行的时间很长,而执行结果无需实时向用户反馈时,也很适合使用MDB。如订单成功后给用户发送一封电子邮件或发送一条短信等。
消息有下面几种类型,他们都是派生自Message接口。
StreamMessage:一种主体中包含Java基本值流的消息。其填充和读取均按顺序进行。
MapMessage:一种主体中包含一组名-值对的消息。(没有定义条目顺序)
TextMessage:一种主体中包含Java字符串的消息(例如:XML消息)
ObjectMessage:一种主体中包含序列化Java对象的消息。
BytesMessage:一种主体中包含连续字节流的消息。
消息的传递模型:
JMS支持两种消息传递模型:点对点(point-to-point,简称PTP)和发布/订阅(publish/subscribe,简称pub/sub)。
二者有以下区别:
1.PTP 消息传递模型规定了一条消息只能传递给一个接收方。采用javax.jms.Queue表示。
2.Pub/sub 消息传递模型允许一条消息传递给多个接收方。采用javax.jms.Topic表示。
注意:每种模型都通过扩展公用基类来实现。例如,javax.jms.Queue 和javax.jms.Topic都扩展自javax.jms.Destination 类。
开发步骤如下:
一、配置destinations-service.xml文件。
JBOSS使用一个XML文件配置队列地址,文件的取名格式应遵循*-service.xml,我取名为destinations-service.xml。
jboss默认的全局JNDI名称组成为:"queue"+"/"+"目标地址"。
开始JMS编程前,我们需要先配置消息到达的目标地址(Destination),因为只有目标地址存在了,我们才能发送消息到这个地址。由于每个应用服务器关于目标地址的配置方式都有所不同,下面以jboss为例,配置一个queue类型的目标地址。
<?xml version="1.0" encoding="UTF-8"?>
<server>
<mbean code="org.jboss.mq.server.jmx.Queue"
name="jboss.mq.destination:service=Queue,name=ztfQueue">
<attribute name="JNDIName">queue/ztfQueue</attribute>
<depends optional-attribute-
name="DestinationManager">jboss.mq:service=DestinationManager</depends>
</mbean>
<mbean code="org.jboss.mq.server.jmx.Topic"
name="jboss.mq.destination:service=Topic,name=ztfTopic">
<attribute name="JNDIName">topic/ztfTopic</attribute>
<depends optional-attribute-
name="DestinationManager">jboss.mq:service=DestinationManager</depends>
</mbean>
</server>
注意:任何队列或主题被部署之前,应用服务器必须先部署Destination Manager Mbean,所有我们通过<depends>节点声明这一依赖。
二、在java类中发送消息(用到jndi.properties)。
一般发送消息有以下步骤:
1.得到一个JNDI初始化上下文(Context)
InitialContext ctx = new InitialContext();
2.根据上下文查找一个连接工厂ConnectionFactory,改连接工厂是由JMS提供的,不需我们自己创建,每个厂商都为它绑定了一个全局JNDI,我们通过它的全局JNDI便获取它;
QueueConnectionFactory factory = (QueueConnectionFactory)ctx.lookup("ConnectionFactory");
3.从连接工厂得到一个连接QueueConnection。
QueueConnection conn = factory.createQueueConnection();
4.通过连接来建立一个会话(Session);
QueueSession session = conn.createQueueSession(false,QueueSession.AUTO_ACKNOWLEDGE);
这句代码意思是:建立不需要事务的并且能自动确立消息已接收的会话。
5.查找目标地址:
Destination destination=(Destination)ctx.lookup("queue/ztfQueue");
6.根据会话以及目标地址来建立消息生产者MessageProducer(QueueSender和TopicPublisher都扩展自MessageProducer接口):
MessageProducer producer = session.createProducer(destination);
TextMessage msg = session.createTextMessage("您好:荆州,这是我的第一个消息驱动Bean");
producer.send(msg);
三、采用MessageDrivenBean接收消息。
当容器检测到bean守候的目标地址有消息到达时,容器调用onMessage()方法,将消息作为参数传入MDB。MDB在onMessage()中决定如何处理改消息。你可以使用注解指定MDB监听哪一个目标地址(Destination)。当MDB部署时,容器将读取其中的配置信息。
一个MDB通常要实现MessageListener接口,在接口定义了onMessage()方法。Bean通过它来处理收到的JMS消息。
@MessageDriven(activationConfig=
{
@ActivationConfigProperty
(propertyName="destinationType",propertyValue="javax.jms.Queue"),
@ActivationConfigProperty
(propertyName="destination",propertyValue="queue/ztfQueue"),
@ActivationConfigProperty(propertyName="acknowledgeMode",propertyValue="Auto-
acknowledge")
})
public class MessageDrivenBean implements MessageListener{
public void onMessage(Message message) {
TextMessage msg = (TextMessage)message;
try {
System.out.println(msg.getText());
} catch (JMSException e) {
e.printStackTrace();
}
}
}
四、把工程src下的文件打成jar包(用到build.xml),在C:\jboss-5.0.0.GA\server\default\deploy进行部署。
五、运行发送消息的java类,此时在console中就可看见结果了。
六、至此,一个MessageDrivenBean开发就成功了。
发表评论
-
Message Broker 中JavaCompute Node 的一个示例
2012-11-14 15:00 1005具体示例见附件. -
MessageBroker FileInput Node Demo
2012-11-06 14:57 884http://user.qzone.qq.com/819713 ... -
修改MQ字符编码集
2012-07-04 16:15 1843MQ字符编码集 1. 首先确 ... -
EJB3.0 MDB的实现
2012-06-25 17:11 1125 EJB3.0 MDB的实现 2009 ... -
Spring实现IBMMQ的JMS消息发布/订阅模式
2012-06-21 16:08 3189<?xml version="1.0" ... -
WAS7 集群手册
2012-06-12 17:02 1000见附件. -
Spring JMSTemplate 与 JMS 原生API比较
2012-04-20 17:03 18322JMSUtil与Spring JmsTempl ... -
WAS7.0 + MQ 7.0 + JNDI 最简配置和收发示例
2012-04-12 17:29 57471、MQ上新建QM和MQ Q ... -
websphere部署war报错:发生 IWAE0022E Exception
2012-03-05 18:06 1500问题主要原因: J2EE版本过高. 环境: ... -
关于 WebSphere 的应用部署
2012-03-05 17:28 1688关于 WebSphere 的应用部署作者: Walter ... -
IBM MessageBroker笔记系列
2012-01-23 10:55 915http://user.qzone.qq.com/242641 ... -
MB与MQ简介
2012-01-21 18:17 1221原文地址:http://space.itpub.net/? ... -
MQ 教程
2011-12-21 15:44 820见附件 -
websphere 6.1 删除概要文件
2011-05-24 18:37 1405方案一:使用命令manageprofiles.bat cd D ... -
【zt】MyEclipse5.5GA配置Websphere V6.1 全过程(详细版)
2011-05-24 18:27 1208原文地址:http://blogold.chinaunix.n ... -
ActiveMQ实践:松耦合和ActiveMQ
2011-01-10 10:28 19532010-10-28 作者:B ... -
使用Spring JMS轻松实现异步消息传递
2011-01-07 17:31 3129异步进程通信是面向服务架构(SOA)一个重要的组成部分 ... -
Apache ActiveMQ教程(六)
2011-01-07 16:59 1897Apache ActiveMQ教程(六) 4 ... -
Apache ActiveMQ教程(五)
2011-01-07 16:58 1553Apache ActiveMQ教程(五) 2008-0 ... -
Apache ActiveMQ教程(四)
2011-01-07 16:57 1682七、ActiveMQ与Tomcat整合 说明:To ...
相关推荐
### EJB2.0与EJB3.0的主要区别 #### 一、简介 企业Java Beans(EJB)是Java平台为企业级应用提供的一种组件模型。随着技术的发展,EJB经历了多个版本的迭代,其中EJB 2.0和EJB 3.0是两个重要的里程碑版本。本文将...
综上所述,"EJB3.0实例教程(源代码).rar"是一个宝贵的资源,它不仅提供了EJB 3.0的理论知识,还通过实际代码示例加深了理解和应用。学习这个教程,你将能够掌握EJB 3.0的核心概念,并有能力创建和部署自己的EJB组件...
- 在EJB3.0项目中,选择`New` -> `Other` -> `EJB3.0` -> `MessageDrivenBean`。 - 输入包名和类名(例如`demo.HelloMDB`)。 2. **配置JMS资源**: - **设置ConnectionFactory**:使用JBoss提供的默认...
10. **MessageDrivenBean** - 消息驱动bean是ejb3.0中处理消息的特殊类型bean,常用于JMS(Java Message Service)。`MessageDrivenBean`可能包含了如何接收和处理消息的示例,实现异步处理和解耦。 通过学习这些...
`MessageDrivenBean`是EJB3.0中处理消息队列(JMS)的组件。该示例将演示如何创建消息驱动bean来监听和处理消息,以及如何配置消息资源。 #### 2.8 `WSClient` 在现代企业应用中,Web服务的集成是常见的需求。`...
本教程将深入探讨EJB3.0中的关键知识点,结合提供的实例代码进行详细解析。 1. **数据源配置(mysql-ds.xml)** 在`mysql-ds.xml`中,我们通常会看到用于配置JDBC数据源的设置,例如数据库连接URL、用户名、密码等...
10. **MessageDrivenBean**:消息驱动bean(MDB)是EJB 3.0中处理JMS(Java Message Service)消息的特殊类型。MDB可以异步接收和处理消息,使其成为实现解耦和异步处理的理想选择。 通过以上实例,开发者可以全面...
通过对上述知识点的深入学习,开发者不仅能够理解 EJB3.0 的基础概念和技术细节,还能够掌握如何在实际项目中有效地利用 EJB3.0 进行高效的企业级应用开发。这将有助于提升项目的质量和开发效率,同时也能更好地应对...
10. **消息驱动bean** - `MessageDrivenBean`是EJB3.0中的另一个组件,用于处理JMS(Java Message Service)消息。它们在后台监听消息队列,当收到消息时自动触发处理。 以上各个部分结合在一起,构成了一个全面的...
1. 注解驱动:EJB3.0放弃了EJB2.x中的XML配置,大量使用注解(Annotation)来声明Bean的元数据,如@Stateless、@Stateful、@MessageDriven等,这大大减少了配置文件的工作量。 2. 自动持久化:EJB3.0引入了JPA...
11. **MessageDrivenBean**:消息驱动bean是EJB中的一种特殊类型,用于监听消息队列并响应JMS(Java Message Service)消息。MessageDrivenBean部分可能包括了如何接收和处理消息的示例。 通过深入学习和理解这些源...
通过这个主题,开发者可以学习到如何在旧版Java EE环境中利用消息驱动Bean进行异步处理,这对于理解更高级的Java EE技术,如EJB3.0和微服务架构,有着重要的基础作用。同时,这也是一种宝贵的技能,因为许多遗留系统...