如何在python3中使用amqp镜像队列?

时间:2012-12-20 06:19:17

标签: queue rabbitmq amqp mirror python-3.2

我使用rabbitmq作为amqp服务器(集群)和kombu + py-amqp作为amqp client.i可以发送/ recv消息正常消息队列,但我不知道如何发送/ recv消息为镜像队列,我无法用google .how发送/ recv镜像队列消息找到答案?

我的代码:

 with Connection(hostname='192.168.1.10',userid='test',password='test',virtual_host='test') as conn:
        simple_queue = conn.SimpleQueue('test')

并获得例外

  File "./test_amqp.py", line 38, in send
    simple_queue = conn.SimpleQueue('test')
  File "/usr/local/lib/python3.2/site-packages/kombu/connection.py", line 671, in SimpleQueue
    exchange_opts, **kwargs)
  File "/usr/local/lib/python3.2/site-packages/kombu/simple.py", line 122, in __init__
    consumer = messaging.Consumer(channel, queue)
  File "/usr/local/lib/python3.2/site-packages/kombu/messaging.py", line 338, in __init__
    self.revive(self.channel)
  File "/usr/local/lib/python3.2/site-packages/kombu/messaging.py", line 350, in revive
    self.declare()
  File "/usr/local/lib/python3.2/site-packages/kombu/messaging.py", line 360, in declare
    queue.declare()
  File "/usr/local/lib/python3.2/site-packages/kombu/entity.py", line 471, in declare
    self.queue_declare(nowait, passive=False)
  File "/usr/local/lib/python3.2/site-packages/kombu/entity.py", line 497, in queue_declare
    nowait=nowait)
  File "/usr/local/lib/python3.2/site-packages/amqp/channel.py", line 1240, in queue_declare
    (50, 11),  # Channel.queue_declare_ok
  File "/usr/local/lib/python3.2/site-packages/amqp/abstract_channel.py", line 70, in wait
    return self.dispatch_method(method_sig, args, content)
  File "/usr/local/lib/python3.2/site-packages/amqp/abstract_channel.py", line 88, in dispatch_method
    return amqp_method(self, args)
  File "/usr/local/lib/python3.2/site-packages/amqp/channel.py", line 222, in _close
    (class_id, method_id), ChannelError)
amqp.exceptions.PreconditionFailed: Queue.declare: (406) PRECONDITION_FAILED - inequivalent arg 'x-ha-policy'for queue 'smarton' in vhost 'smarton': received none but current is the value 'all' of type 'longstr'

2 个答案:

答案 0 :(得分:0)

声明队列时,所有选项必须与服务器上已存在的选项相同。在这种情况下,服务器的额外选项为'x-ha-policy': 'all'

尝试simple_queue = conn.SimpleQueue('test', queue_opts={"x-ha-policy": "all"})

我还没有测试过这个,但我认为它会起作用。

答案 1 :(得分:0)

也许有一些关于kombu的问题,论点:{“x-ha-policy”:“all”}应该发布到entity.Queue.queue_arguments,但是strre是没有entity.Queue的方法来设置值entity.Queue.queue_arguments,我改变了kombu.simple.SimpleQueue并获得了正确的结果:

112         if not isinstance(queue, entity.Queue):
113             exchange = entity.Exchange(name, 'direct', **exchange_opts)
114             queue = entity.Queue(name, exchange, name, **queue_opts)
115+            queue.queue_arguments={'x-ha-policy':'all'}
116         else:
117             name = queue.name
118             exchange = queue.exchange