EJB3.0消息驱动bean(MDB)

EJB3.0中的消息驱动beanjava消息服务技术(JMS)是用于访问企业消息系统的开发商中立的API。企业消息系统可以协助应用软件通过网络进行消息交互。

JMS的编程过程很简单,概括为:应用程序A发送一条消息到消息服务器的某个目的地(Destination),然后消息服务器把消息转发给应用程序B。因为应用程序A和应用程序B没有直接的代码关联,所以两者实现了解耦,如下图:

消息的传递模型

JMS支持两种消息传递模型,点对点(point-to-pointPTP)和发布/订阅(publish/subscribe,简称pub/sub)。这两种消息传递模型非常相似,但有以下区别:

PTP消息传递模型规定了一条消息只能传递给一个接收方,采用javax.jms.Queue表示。

Pub/sub消息传递模型允许一条消息传递个多个接收方,采用javax.jms.Topic表示。

这两种模型都通过扩展公用的基类来实现。例如:javax.jms.Queuejavax.jms.Topic都扩展自javax.jms.Destination类。

点对点消息传递

通过点对点(PTP)的消息传递模型,一个应用程序可以向另一个应用程序发送消息。在此传递模型中,目标类型是队列。消息首先被传送至队列目标,然后从该队列将消息传送至对此队列进行监听的某个消费者,如下图:

一个队列可以关联多个队列发送方和接收方,但一条消息仅传递给一个接收方。如果多个接收方正在监听队列上的消息,JMS Provider将根据“先来者优先”的原则确定由哪个接收方接收下一条消息。如果没有接收方在监听队列,消息将保留在队列中,直至接收方连接到队列为止。这种消息传递模型是传统意义上的拉模型,在此模型中,消息不是自动推送给客户端的,而是要有客户端从队列中请求获得。

发布/订阅消息传递

通过发布/订阅(pub/sub)消息传递模型,应用程序能够将一条消息发送到多个接收方。在此传送模型中,目标类型是主题。消息首先被传送至主题目标,然后传送至所有已订阅此主题的活动消费者。如下图:

Pub/sub消息传递模型允许多个主题订阅者接收同一条消息。JMS一直保留消息,直至所有主题订阅者都收到消息为止。Pub/sub消息传递模型基本上是一个推模型。在该模型中,消息会自动广播,消费者无须通过主动请求方式获得新的消息。

配置目标地址mydestination-service.xml,支持上面讲的两种模型

把该目标地址发布到jboss中(复制该文件到%JBOSS_HOME%/server/default/deploy下面)。

编写queue模型的发送者类

 编写queue模型接收方类(通过消息驱动)

编写topic模型发送方类

 编写topic模型接收方类A(通过消息驱动)

 编写topic模型接收方类B(通过消息驱动)

 发布该项目到jboss服务器中,启动jboss服务器。

运行queue模型发送方类的main方法,得到结果:

你好,我是queue消息驱动bean

运行topic模型发送方类的main方法,得到结果:
class wang.message.ReceiveBeanA你好,我是topic消息驱动bean

class wang.message.ReceiveBeanB你好,我是topic消息驱动bean

两个接收方都得到了消息。

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值