JBoss JMS Удаленная очередь? - PullRequest
5 голосов
/ 14 декабря 2009

Я хочу отправлять сообщения в удаленную очередь? какие шаги я должен сделать я не могу найти документацию об этом? кто-нибудь может помочь ??

Ответы [ 2 ]

6 голосов
/ 16 декабря 2009

Добавьте еще один «JMSProvider» в ваш $ {JBOSS_CONF} /deploy/messaging/jms-ds.xml. Я использую имя провайдера «RemoteJMSProvider» в этом примере:

<!-- Remote JMS Server-->
<mbean code="org.jboss.jms.jndi.JMSProviderLoader"
  name="jboss.mq:service=JMSProviderLoader,name=RemoteJMSProvider,server=your_remote_host">
    <attribute name="ProviderName">RemoteJMSProvider</attribute>
    <attribute name="ProviderAdapterClass">org.jboss.jms.jndi.JNDIProviderAdapter</attribute>
    <!-- The connection factory -->
    <attribute name="FactoryRef">XAConnectionFactory</attribute>
    <!-- The queue connection factory -->
    <attribute name="QueueFactoryRef">XAConnectionFactory</attribute>
    <!-- The topic factory -->
    <attribute name="TopicFactoryRef">XAConnectionFactory</attribute>
    <!-- Connect to JNDI on the host "the-remote-host-name" port 1099-->
    <attribute name="Properties">
       java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
       java.naming.factory.url.pkgs=org.jnp.interfaces
       java.naming.provider.url=your_remote_host:1099
    </attribute>

Затем добавьте «Фабрика удаленных подключений»:

<tx-connection-factory>
  <jndi-name>RemoteJMSConnectionFactory</jndi-name>
  <xa-transaction/>
  <rar-name>jms-ra.rar</rar-name>
  <connection-definition>org.jboss.resource.adapter.jms.JmsConnectionFactory</connection-definition>
  <config-property name="SessionDefaultType" type="java.lang.String">javax.jms.Queue</config-property>
  <config-property name="JmsProviderAdapterJNDI" type="java.lang.String">java:/RemoteJMSProvider</config-property>
  <max-pool-size>20</max-pool-size>
  <security-domain-and-application>JmsXARealm</security-domain-and-application>
  <depends>jboss.messaging:service=ServerPeer</depends>

Теперь, каждый раз, когда вы создаете ссылку фабрики соединений на «RemoteJMSFactory», любая удаленная вами очередь будет просматриваться на удаленном сервере:

ConnectionFactory factory =(ConnectionFactory)JNDIContext.lookup("java:/RemoteJMSConnectionFactory");
queue = (Destination) JNDIContext.lookup("queue/myqueue");
connection = factory.createConnection();
session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
MessageProducer sender = session.createProducer(queue);
sender.send(jmsMessage);

Смотри также: http://community.jboss.org/wiki/HowDoIConfigureAnMDBToTalkToARemoteQueue

0 голосов
/ 16 декабря 2009

Посмотрите в документах / примерах вашей установки jboss. Единственное изменение, необходимое для подключения к удаленной очереди, - это настроить исходный контекст для ссылки на порт JNDI удаленного сервера приложений.

...