gpt4 book ai didi

java - ActivationSpec 和 ConnectionFactory 有什么区别?

转载 作者:IT老高 更新时间:2023-10-28 20:52:28 25 4
gpt4 key购买 nike

我的理解是:

  • MDBs(消息驱动 Bean)通过激活规范连接。
  • MDPs(消息驱动 POJO)通过连接工厂连接。

此图from IBM很有帮助:

enter image description here

对我来说,this explanation from IBM并没有说明差异:

  • 连接工厂 -- 应用程序使用它来连接到消息传递总线。
  • 队列 -- 应用程序用来发送和接收消息。
  • 激活规范 -- 由应用程序的消息驱动 bean 用于连接到队列并接收消息。

一个真实的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 是:

  • 将 ActivationSpec 与 MDB 结合使用,将 ConnectionFactory 与 POJO 结合使用(等等,POJO 可以 use ActivationSpec too 吗?)
  • MDB 以异步方式运行。 MBP 同步运行。

我的问题是:还有其他区别吗?你能澄清一下区别吗?

引用资料:

最佳答案

@Jeffrey Knight:让我根据我的经验来澄清一下。

我们理解 MDB 是使用传入消息的 bean。现在需要指定特定 MDB 想要从哪个目的地消费什么类型的消息。

MDB 基本上是一个消息端点。

在符合 JCA 的 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 之后,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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com