Java QPID为0.32客户端的RabbitMQ消息传递

Java QPID为0.32客户端的RabbitMQ消息传递,java,rabbitmq,amqp,qpid,Java,Rabbitmq,Amqp,Qpid,使用QPID Java客户端,我只能使用以下扩展的AMQANYDESTINDATION语法通过exchange将消息传递到绑定队列 Destination queue = new AMQAnyDestination( new AMQShortString("onms2"), new AMQShortString("direct"),

使用QPID Java客户端,我只能使用以下扩展的AMQANYDESTINDATION语法通过exchange将消息传递到绑定队列

Destination queue = new AMQAnyDestination( new AMQShortString("onms2"), 
                                               new AMQShortString("direct"),
                                               new AMQShortString("Simon"),
                                               true,        
                                               true,        
                                               new AMQShortString(""),
                                               false,       
                                               bindvars);
如果我尝试使用不同的表单,只指定如下地址,则它不起作用:-

Destination queue = new AMQAnyDestination("onms2/Simon");
消息命中RabbitMQ ok,但未传递

Qpid 0.32客户端 兔MQ 3.5.7

交换onms 路由密钥Simon

我一直在使用qpid示例并修改ListSender示例,如下所示

package org.apache.qpid.example;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import javax.jms.Connection;
import javax.jms.Destination;
import javax.jms.Message;
import javax.jms.MessageProducer;
import javax.jms.Session;

import org.apache.qpid.client.AMQAnyDestination;
import org.apache.qpid.client.AMQConnection;

import org.apache.qpid.framing.AMQShortString;
import org.apache.qpid.jms.ListMessage;


public class ListSender {

public static void main(String[] args) throws Exception
{
    Connection connection =
        new AMQConnection("amqp://simon:simon@localhost/test?brokerlist='tcp://localhost:5672'");
                                               AMQShortString a1 = new AMQShortString("");
                                               AMQShortString a2 = new AMQShortString("");
    AMQShortString[] bindvars = new AMQShortString[]{a1,a2};
    boolean is_durable = true;
    /*
    Destination queue = new AMQAnyDestination( new AMQShortString("onms2"), 
                                               new AMQShortString("direct"),
                                               new AMQShortString("Simon"),
                                               true,        
                                               true,        
                                               new AMQShortString(""),
                                               false,       
                                               bindvars);
    */

    Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
    Destination queue = new AMQAnyDestination("onms2/Simon");
    //Destination queue = new AMQAnyDestination("amqp:OpenNMSExchange/Taylor; {create: always}");
    //Destination queue = new AMQAnyDestination("OpenNMSExchange; {create: always}");
    MessageProducer producer = session.createProducer(queue);

ListMessage m = ((org.apache.qpid.jms.Session)session).createListMessage();
    m.setIntProperty("Id", 987654321);
    m.setStringProperty("name", "WidgetSimon");
    m.setDoubleProperty("price", 0.99);

    List<String> colors = new ArrayList<String>();
    colors.add("red");
    colors.add("green");
    colors.add("white");
    m.add(colors);

    Map<String,Double> dimensions = new HashMap<String,Double>();
    dimensions.put("length",10.2);
    dimensions.put("width",5.1);
    dimensions.put("depth",2.0);
    m.add(dimensions);

    List<List<Integer>> parts = new ArrayList<List<Integer>>();
    parts.add(Arrays.asList(new Integer[] {1,2,5}));
    parts.add(Arrays.asList(new Integer[] {8,2,5}));
   m.add(parts);

    Map<String,Object> specs = new HashMap<String,Object>();
    specs.put("colours", colors);
    specs.put("dimensions", dimensions);
    specs.put("parts", parts);
    m.add(specs);

    producer.send((Message)m);
    System.out.println("Sent: " + m);
    connection.close();
}

}
使用较短的语法失败时,调试日志如下所示:-

163  [main] INFO  org.apache.qpid.client.AMQConnection  - Connection 1 now connected from /127.0.0.1:43298 to localhost/127.0.0.1:5672
163  [main] DEBUG org.apache.qpid.client.AMQConnection  - Are we connected:true
163  [main] DEBUG org.apache.qpid.client.AMQConnection  - Connected with ProtocolHandler Version:0-91
166  [main] DEBUG org.apache.qpid.client.AMQDestination  - Based on direct://onms2/Simon/?routingkey='Simon'&exclusive='true'&autodelete='true' the selected destination syntax is BURL
169  [main] DEBUG org.apache.qpid.client.AMQConnectionDelegate_8_0  - Write channel open frame for channel id 1
184  [main] DEBUG org.apache.qpid.client.AMQSession  - Created session:org.apache.qpid.client.AMQSession_0_8@1d251891
186  [IoReceiver - localhost/127.0.0.1:5672] DEBUG org.apache.qpid.client.protocol.AMQProtocolHandler  - (1028176102)Method frame received: [ChannelOpenOkBody]
189  [IoReceiver - localhost/127.0.0.1:5672] DEBUG org.apache.qpid.client.protocol.AMQProtocolHandler  - (1028176102)Method frame received: [BasicQosOkBodyImpl: ]
195  [main] DEBUG org.apache.qpid.client.BasicMessageProducer_0_8  - MessageProducer org.apache.qpid.client.BasicMessageProducer_0_8@668bc3d5 using publish mode : ASYNC_PUBLISH_ALL
206  [main] DEBUG org.apache.qpid.client.BasicMessageProducer_0_8  - Sending content body frames to direct://onms2/Simon/?routingkey='Simon'&exclusive='true'&autodelete='true'
206  [main] DEBUG org.apache.qpid.client.BasicMessageProducer_0_8  - Sending content header frame to direct://onms2/Simon/?routingkey='Simon'&exclusive='true'&autodelete='true'
207  [main] DEBUG org.apache.qpid.framing.FieldTable  - FieldTable::writeToBuffer: Writing encoded length of 67...
149  [main] INFO  org.apache.qpid.client.AMQConnection  - Connection 1 now connected from /127.0.0.1:36940 to localhost/127.0.0.1:5672
149  [main] DEBUG org.apache.qpid.client.AMQConnection  - Are we connected:true
149  [main] DEBUG org.apache.qpid.client.AMQConnection  - Connected with ProtocolHandler Version:0-91
153  [main] DEBUG org.apache.qpid.client.AMQConnectionDelegate_8_0  - Write channel open frame for channel id 1
169  [main] DEBUG org.apache.qpid.client.AMQSession  - Created session:org.apache.qpid.client.AMQSession_0_8@6bdf28bb
170  [IoReceiver - localhost/127.0.0.1:5672] DEBUG org.apache.qpid.client.protocol.AMQProtocolHandler  - (472294496)Method frame received: [ChannelOpenOkBody]
171  [IoReceiver - localhost/127.0.0.1:5672] DEBUG org.apache.qpid.client.protocol.AMQProtocolHandler  - (472294496)Method frame received: [BasicQosOkBodyImpl: ]
179  [main] DEBUG org.apache.qpid.client.AMQDestination  - Based on onms2/Simon the selected destination syntax is ADDR
182  [main] DEBUG org.apache.qpid.client.AMQConnectionDelegate_8_0  - supportsIsBound: false
182  [main] DEBUG org.apache.qpid.client.AMQConnectionDelegate_8_0  - supportsIsBound: false
182  [main] DEBUG org.apache.qpid.client.AMQConnectionDelegate_8_0  - supportsIsBound: false
184  [IoReceiver - localhost/127.0.0.1:5672] DEBUG org.apache.qpid.client.protocol.AMQProtocolHandler  - (472294496)Method frame received: [ExchangeDeclareOkBodyImpl: ]
184  [main] DEBUG org.apache.qpid.client.BasicMessageProducer_0_8  - MessageProducer org.apache.qpid.client.BasicMessageProducer_0_8@15975490 using publish mode : ASYNC_PUBLISH_ALL
195  [main] DEBUG org.apache.qpid.client.BasicMessageProducer_0_8  - Sending content body frames to 'onms2'/'Simon'; None
195  [main] DEBUG org.apache.qpid.client.BasicMessageProducer_0_8  - Sending content header frame to 'onms2'/'Simon'; None
196  [main] DEBUG org.apache.qpid.framing.FieldTable  - FieldTable::writeToBuffer: Writing encoded length of 90...
196  [main] DEBUG org.apache.qpid.framing.FieldTable  - {Id=[INT: 987654321], name=[LONG_STRING: WidgetSimon], price=[DOUBLE: 0.99], qpid.subject=[LONG_STRING: Simon], JMS_QPID_DESTTYPE=[INT: 2]}
198  [main] DEBUG org.apache.qpid.client.AMQSession  - Closing session: org.apache.qpid.client.AMQSession_0_8@6bdf28bb
198  [main] DEBUG org.apache.qpid.client.protocol.AMQProtocolSession  - closeSession called on protocol session for session 1
理想情况下,我需要较短的语法来工作,因为我正在使用的另一个应用程序正在使用AMQP发布消息

我怀疑我用来定义地址的语法不正确,但我看不出它是什么

我试过:-

amqp:onms2/Simon 地址:onms2/Simon

我已经通过使用qpid的独立java客户机以及使用perl(使用net_amqp)和python(使用pika)进行测试,确认了rabbit配置是正确的。所以我不这么认为

任何古迪亚人都很感激

编辑:- 在我错过的QPID上找到了一些额外的配置参数 当我配置地址如下它的工作! onms3/Simon;{'create':'always','node':{'type':'topic'} 细部

[/];{
创建:始终|发送方|接收方|从不,
删除:始终|发送方|接收方|从不,
断言:始终|发送方|接收方|从不,
模式:浏览|消费,
节点:{
类型:队列|主题,
持久性:对|错,
x-声明:{……},
x绑定:[,…]
},
链接:{
姓名:,
持久性:对|错,
可靠性:不可靠|最多一次|至少一次|恰好一次,
x-声明:{……},
x-绑定:[,…],
x-订阅:{……}
}
}
西蒙编辑: 在我错过的QPID上找到了一些额外的配置参数 当我配置地址如下它的工作

onms3/Simon; {'create':'always','node':{'type':'topic'} }
细部

<name> [ / <subject> ] ; {
create: always | sender | receiver | never,
delete: always | sender | receiver | never,
assert: always | sender | receiver | never,
mode: browse | consume,
node: {
type: queue | topic,
durable: True | False,
x-declare: { ... <declare-overrides> ... },
x-bindings: [<binding_1>, ... <binding_n>]
},
link: {
name: <link-name>,
durable: True | False,
reliability: unreliable | at-most-once | at-least-once | exactly-once,
x-declare: { ... <declare-overrides> ... },
x-bindings: [<binding_1>, ... <binding_n>],
x-subscribe: { ... <subscribe-overrides> ... }
}
}
[/];{
创建:始终|发送方|接收方|从不,
删除:始终|发送方|接收方|从不,
断言:始终|发送方|接收方|从不,
模式:浏览|消费,
节点:{
类型:队列|主题,
持久性:对|错,
x-声明:{……},
x绑定:[,…]
},
链接:{
姓名:,
持久性:对|错,
可靠性:不可靠|最多一次|至少一次|恰好一次,
x-声明:{……},
x-绑定:[,…],
x-订阅:{……}
}
}

我用答案编辑了自己的问题。不确定你的意思-请详细说明。
<name> [ / <subject> ] ; {
create: always | sender | receiver | never,
delete: always | sender | receiver | never,
assert: always | sender | receiver | never,
mode: browse | consume,
node: {
type: queue | topic,
durable: True | False,
x-declare: { ... <declare-overrides> ... },
x-bindings: [<binding_1>, ... <binding_n>]
},
link: {
name: <link-name>,
durable: True | False,
reliability: unreliable | at-most-once | at-least-once | exactly-once,
x-declare: { ... <declare-overrides> ... },
x-bindings: [<binding_1>, ... <binding_n>],
x-subscribe: { ... <subscribe-overrides> ... }
}
}