- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我的理解是:
此图from IBM很有帮助:
对我来说,this explanation from IBM并没有说明差异:
一个真实的difference I have found is that :
Session beans and entity beans [aka MDPs] allow you to send JMS messages and to receive them synchronously, but not asynchronously. To avoid tying up server resources, you may prefer not to use blocking synchronous receives in a server-side component. To receive messages asynchronously, use a message-driven bean [MDB].
所以到目前为止我不满意的 list 是:
我的问题是:还有其他区别吗?你能澄清一下区别吗?
引用资料:
最佳答案
@Jeffrey Knight:让我根据我的经验来澄清一下。
我们理解 MDB 是使用传入消息的 bean。现在需要指定特定 MDB 想要从哪个目的地消费什么类型的消息。
MDB 基本上是一个消息端点。
websphere 中的流量是:-
incoming message --> listened by Message listener --> listener ports-->deliver to MDB
所以通常开发人员会创建一个 MDB 并在 ejb-jar.xml 中指定消息目标详细信息,如下所示:-
<message-driven-destination>
<destination-type>javax.jms.Queue</destination-type>
</message-driven-destination>
<res-ref-name>jms/QCF</res-ref-name>
<resource-ref>
<res-type>javax.jms.QueueConnectionFactory</res-type>
<res-auth>Container</res-auth>
</resource-ref>
部署者需要创建监听器端口并将部署的 MDB 关联到监听器端口。上面指定的 QueueConnectionFactory 用于创建到队列的连接。
在 JCA 之后,MDB 被视为 JCA 资源。 JCA 规范也包含了消息传递框架 API。 JCA 情况下的流程是:-
incoming message --> listened by Message listener --> Resource Adapter-->deliver to MDB
现在,由于创建 JCA 是为了与任何类型的资源(如 JDBC、JMS、EIS 等)一起工作,因此它具有为任何适配器创建配置的通用“激活规范”方式。在 ra.xml 文件中,提到了该特定适配器需要什么样的激活规范才能工作。激活规范不是运行时实体,它只是资源适配器使用的配置细节。在上述情况下,JCA 适配器将使用来自激活规范中提到的队列连接工厂的连接。所以基本上上述两种情况下的队列连接工厂都是一样的。
对于 websphere,您可以使用 SIB(服务集成总线)目标进行消息传递,也可以使用 websphere MQ 等外部软件进行消息传递。
如果是用于消息传递的 SIB 目的地:-SIB 已经实现了一个 JCA 资源适配器。因此,在 SIB 上使用目标的 MDB 可以使用激活规范来指定目标详细信息。资源适配器模块可以与消息传递引擎交互,并将消息传递给MDB。
如果是 websphere MQ 等外部消息传递框架:-由于 websphere MQ 没有实现任何 JCA 适配器,所以我们需要配置监听器端口以连接到驻留在 websphere MQ 上的目标。将消息传递到 MDB 的是监听器端口。
简而言之,这两种情况都使用队列连接工厂来获取队列连接。在一种情况下,它是用于传递消息的资源适配器(具有激活规范形式的配置信息),而在另一种情况下,它是用于传递消息的监听器端口(绑定(bind)到队列和工厂)。
我希望现在可以澄清这一点。
关于java - ActivationSpec 和 ConnectionFactory 有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7390286/
我的理解是: MDBs(消息驱动 Bean)通过激活规范连接。 MDPs(消息驱动 POJO)通过连接工厂连接。 此图from IBM很有帮助: 对我来说,this explanation from
我目前正在使用 WebSphere-MQSeries 为 WebSphere AS 7 开发一个小型 EJB 3 应用程序。这是一个非常简单的应用程序,主要由一个 MDB 组成,该 MDB 监听队列,
我是一名优秀的程序员,十分优秀!