0

根据文档https://console.ng.bluemix.net/docs/services/MessageHub/index.html#messagehub应该可以通过 REST 向 MessageHub 提交消息并通过 MQLight 客户端接收它。但是,文档缺少示例并且有些……不透明。

所以,如果我创建 MQLight 主题,并让 python 客户端监听,

    import json
    import logging
    import mqlight
    import time

    amqps = 'amqps://xxxxxxxxxxxxx.messagehub.services.us-south.bluemix.net:5671'
    options = {
        'user' : 'xxxxxxxxxxxxxxxx',
        'password' : 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
    }

    def on_message(message_type, data, delivery):
        d = json.loads(data)
        print str(d)

    def on_started(err):
        client.subscribe('test', on_message = on_message)

    def on_stopped(err):
        logging.info('stopped')

    client = mqlight.Client(amqps, security_options = options, client_id = 'client', on_started=on_started)

    while True:
        logging.info(str(client.get_state()))
        time.sleep(5)

我将如何通过 curl 发布消息。我试过了,值字符串是base64编码的,

    curl  -i                                                                                                      \
          -X POST                                                                                                 \
          -H "X-Auth-Token:${APIKEY}"                                                                             \
          -H "Content-Type: application/vnd.kafka.binary.v1+json"                                                 \
          --data '{"records":[{"value":"S2Fma2E="}]}'                                                             \
          "https://kafka-rest-prod01.messagehub.services.us-south.bluemix.net:443/topics/MQLight/test"

但那又回来了,

    {"error_code":404,"message":"HTTP 404 Not Found"}
4

1 回答 1

1

您说得对,这里的文档并没有特别充实。唯一的细节是在这里的一小部分,它试图解释为了与来自其他 Kafka 或 REST 客户端的 MQLight 客户端进行互操作,您需要能够编码/解码 AMQP 1.0 消息格式(参见规范的第 3 节)。

你很难在 curl 脚本中实现这一点,因为你需要访问 AMQP 1.0 库,甚至 Python 也不是理想的,因为目前你唯一真正的选择是引入python-qpid-proton,它非常重量级,因为它包装proton-c 本机库,因此需要安装时编译。

例如,在 Java 中,您可以使用官方 Java kafka-clients和 qpid proton-j的组合来提供 AMQP 消息编码 + 解码。或者,如果您必须使用 REST api,请使用feign之类的内容。

于 2016-09-20T14:35:21.283 回答