JBoss JMS 远程队列?

JBoss JMS Remote Queue?

我想向远程队列发送消息?我应该做什么步骤
我找不到任何相关文件?
任何人都可以帮忙?? ?


在您的 ${JBOSS_CONF}/deploy/messaging/jms-ds.xml 中添加另一个"JMSProvider"。在此示例中,我使用提供程序名称"RemoteJMSProvider":

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<!-- Remote JMS Server-->
<mbean code="org.jboss.jms.jndi.JMSProviderLoader"
  name="jboss.mq:service=JMSProviderLoader,name=RemoteJMSProvider,server=your_remote_host">
    RemoteJMSProvider</attribute>
    org.jboss.jms.jndi.JNDIProviderAdapter</attribute>
    <!-- The connection factory -->
    XAConnectionFactory</attribute>
    <!-- The queue connection factory -->
    XAConnectionFactory</attribute>
    <!-- The topic factory -->
    XAConnectionFactory</attribute>
    <!-- Connect to JNDI on the host"the-remote-host-name" port 1099-->
   
       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>

接下来,添加一个"远程连接工厂":

1
2
3
4
5
6
7
8
9
10
<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"的连接工厂引用时,您引用的任何队列都将在远程服务器上查找:

1
2
3
4
5
6
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


查看您的 jboss 安装的文档/示例。连接到远程队列所需的唯一更改是设置初始上下文以引用远程应用服务器的 JNDI 端口。