0

JBoss EAP6.4 を使用しています。このプロジェクトでは、2 つの MOM を使用しています。1) Websphere MQ 2) Solace MQ これは、上記の 2 つの MOM のリソース アダプタが、standalone.xml で定義されている方法です。

<?xml version='1.0' encoding='UTF-8'?>
<server xmlns="urn:jboss:domain:1.7">
<profile>       

    <subsystem xmlns="urn:jboss:domain:ejb3:1.5">

        <mdb>
            <resource-adapter-ref resource-adapter-name="wmq.jmsra.rar"/>
            <bean-instance-pool-ref pool-name="mdb-strict-max-pool"/>
        </mdb>
        <pools>
            <bean-instance-pools>
                <strict-max-pool name="mdb-strict-max-pool" max-pool-size="20" instance-acquisition-timeout="5" instance-acquisition-timeout-unit="MINUTES"/>
            </bean-instance-pools>
        </pools>

    </subsystem>


    <subsystem xmlns="urn:jboss:domain:resource-adapters:1.1">
        <resource-adapters>

            <resource-adapter id="wmq.jmsra.rar">
                <archive>wmq.jmsra.rar</archive>
                <transaction-support>NoTransaction</transaction-support>
                <config-property name="traceLevel">3</config-property>
                <config-property name="traceEnabled">true</config-property>
                <connection-definitions>
                    <connection-definition class-name="com.ibm.mq.connector.outbound.ManagedQueueConnectionFactoryImpl" jndi-name="java:jboss/jms/myJMSQueueConnectionFactory" enabled="true" use-java-context="true" pool-name="jms/myJMSQueueConnectionFactoryPool">
                        <config-property name="channel">${mq.channel}</config-property>
                        <config-property name="hostName">${mq.host}</config-property>
                        <config-property name="transportType">${mq.transportType}</config-property>
                        <config-property name="queueManager">${mq.manager}</config-property>
                        <config-property name="port">${mq.port}</config-property>                            
                    </connection-definition>
                </connection-definitions>
                <admin-objects>
                    <admin-object class-name="com.ibm.mq.connector.outbound.MQQueueProxy" jndi-name="java:jboss/jms/abcQueue" enabled="true" use-java-context="true" pool-name="jms/abcQueuePool">
                        <config-property name="targetClient">MQ</config-property>
                        <config-property name="persistence">PERS</config-property>
                        <config-property name="expiry">UNLIMITED</config-property>
                        <config-property name="baseQueueName">${my.abc.queue}</config-property>
                        <config-property name="arbitraryProperties">mdMessageContext="2",mdWriteEnabled="true",mdReadEnabled="true"</config-property>
                        <config-property name="baseQueueManagerName">${mq.manager}</config-property>
                    </admin-object>                       
                </admin-objects>
            </resource-adapter>

            <resource-adapter id="com.solacesystems.ra">
                <archive>sol-jms-ra-7.1.2.248.rar</archive>
                <transaction-support>NoTransaction</transaction-support>
                <config-property name="extendedProps">${solace.extendedproperties}</config-property>
                <config-property name="UserName">${solace.username}</config-property>
                <config-property name="MessageVPN">${solace.vpn}</config-property>
                <config-property name="ConnectionURL">${solace.connectionurl}</config-property>
                <config-property name="Password">${solace.password}</config-property>
                <connection-definitions>
                    <connection-definition class-name="com.solacesystems.jms.ra.outbound.ManagedJMSConnectionFactory" jndi-name="java:jboss/jms/solaceMessageConnectionFactory" enabled="true" pool-name="solaceMessageCFPool">
                        <config-property name="ConnectionFactoryJndiName">${solace.connectionfactory}</config-property>
                        <security>
                            <application/>
                        </security>
                        <validation>
                            <background-validation>false</background-validation>
                        </validation>
                        <recovery>
                            <recover-credential>
                                <user-name>${solace.username}</user-name>
                                <password>${solace.password}</password>
                            </recover-credential>
                        </recovery>
                    </connection-definition>
                </connection-definitions>
                <admin-objects>
                    <admin-object class-name="com.solacesystems.jms.ra.outbound.TopicProxy" jndi-name="java:jboss/jms/xyzMessageTopic" enabled="true" use-java-context="false" pool-name="xyzMessageTopicPool">
                        <config-property name="Destination">${xyz.topic}</config-property>
                    </admin-object>
                </admin-objects>
            </resource-adapter>
        </resource-adapters>
    </subsystem>
</profile>

上記のファイルでは、基本的に、WMQ 用と Solace 用の 2 つの resourceAdapter を定義しました。

  • タグの下<mdb>に、デフォルトのリソース アダプタ名を定義<bean-instance-pool-refし、メッセージ駆動型 Bean にデフォルトで使用されるインスタンス プールを制限する値を定義しました。
  • 一部の MDB では、jboss-ejb3.xml を使用して Bean ごとのインスタンス プール値を明示的にオーバーライドしました。

WMQ と SOLACE の両方をリッスンする複数のメッセージ駆動型 Bean があるため、私の質問は次のとおりです。

  1. jboss-ejb3.xml で明示的なプールを定義していない MDB (WMQ キューと SOLACE キューの両方をリッスンする) は、タグ ie で定義された同じデフォルト プールを共有しますか?

    <mdb>
        <resource-adapter-ref resource-adapter-name="wmq.jmsra.rar"/>
        <bean-instance-pool-ref pool-name="mdb-strict-max-pool"/>
    </mdb>
    
  2. または、WMQ キューをリッスンしている MDB にのみデフォルト プールが適用されるようなものですか。

  3. デフォルト プールが WMQ キューをリッスンする MDB にのみ適用される場合、standalone.xml または jboss-ejb3.xml でプール サイズが定義されていない Solace キューをリッスンする MDB はどうなりますか?
4

1 に答える 1

2

1) インスタンス プールが指定されていない MDB は、デフォルトの mdb-strict-max-pool を使用します。独自のプールを定義できます (これをお勧めします)。

        <pools>
            <bean-instance-pools>
                <strict-max-pool name="slsb-strict-max-pool" max-pool-size="20" instance-acquisition-timeout="5" instance-acquisition-timeout-unit="MINUTES"/>
                <strict-max-pool name="mdb-strict-max-pool" max-pool-size="20" instance-acquisition-timeout="5" instance-acquisition-timeout-unit="MINUTES"/>
                <strict-max-pool name="MyPool" max-pool-size="10" instance-acquisition-timeout="5" instance-acquisition-timeout-unit="MINUTES"/>
            </bean-instance-pools>
        </pools>

次に、注釈を使用します。

import org.jboss.ejb3.annotation.Pool;

@Pool(value="MyPool") 

MDB で。これは、デプロイメント記述子ファイルでも実行できます。

2) 上記参照。MDB デプロイメントごとにインスタンス プールを使用することを好みます。インスタンス プールをめぐって MDB が競合するのは好きではありません。

3) 同上。MDB デプロイメントが JMX で使用しているインスタンス プール名を確認できることに注意してください。個別のインスタンス プールがある場合、プールの統計はより意味のあるものになることに注意してください。

于 2016-10-19T15:03:00.833 に答える