- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我似乎无法运行代码 - 我一直在使用 Pika,并热衷于尝试这个线程安全且可能更简洁的版本。
import rabbitpy
with rabbitpy.Connection('amqp://guest:guest@localhost:5672/%2f') as conn:
with conn.channel() as channel:
queue = rabbitpy.Queue(channel, 'example')
# Exit on CTRL-C
try:
# Consume the message
for message in queue:
message.pprint(True)
message.ack()
except KeyboardInterrupt:
print 'Exited consumer'
我得到的错误:
Traceback (most recent call last):
File "newshift.py", line 3, in <module>
with rabbitpy.Connection('amqp://guest:guest@localhost:5672/%2f') as conn:
AttributeError: 'module' object has no attribute 'Connection'
我的系统设置是:
numpy==1.11.2
pamqp==1.6.1
pandas==0.19.0
pika==0.10.0
pkg-resources==0.0.0
python-dateutil==2.5.3
pytz==2016.7
rabbitpy==1.0.0
six==1.10.0
SQLAlchemy==1.1.3
<小时/>
dir(rabbitpy)
['__builtins__', '__doc__', '__file__', '__name__', '__package__']
不知何故,在模块中加载时看不到这些类
最初的问题是由 .pyc 文件挂起引起的,但新的错误消息是:
Traceback (most recent call last):
File "newshift.py", line 15, in <module>
print 'Exited consumer'
File "/home/brett/code/SimpleConsumers/local/lib/python2.7/site-packages/rabbitpy/connection.py", line 149, in __exit__
raise exc_val
rabbitpy.exceptions.AMQPNotFound: <pamqp.specification.Channel.Close object at 0x7f39a91da7d0>
最佳答案
rabbitpy.exceptions.AMQPNotFound: <pamqp.specification.Channel.Close
我认为rabbitpy
给出此错误,因为它尝试连接到不存在的 queue
姓名 example
queue = rabbitpy.Queue(channel, 'example')
但是rabbitpy
如果此队列尚不存在,则不会创建该队列。
我检查了examples with pika他们工作是因为 pika
当队列(名称为 hello
)不存在时创建它,以便它可以安全地从此队列发送和接收。
pika
在两种情况下都会自动创建队列 - 当您发送或接收消息时。
您可以使用命令检查rabbitmq中的现有队列(在Linux上)
sudo rabbitmqctl list_queues
即。结果
Listing queues ...
celery 3
hello 0
...done.
<小时/>
如果我用 pika
发送消息然后我可以通过 rabbitpy
接收它因为pika
如果队列不存在则创建队列,然后 rabbitpy
可以安全地使用这个队列。
看来你必须使用 queue.declare()
如果队列不存在则创建队列。
import rabbitpy
with rabbitpy.Connection('amqp://guest:guest@localhost:5672/%2f') as conn:
with conn.channel() as channel:
queue = rabbitpy.Queue(channel, 'example')
queue.declare() # <---
关于python - 无法获得适用于 RabbitPy 的示例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40385621/
使用示例中的标准过程(for 循环),我们发现机器上使用了大量内存。 IE。似乎队列中的所有消息都已加载到内存中并得到确认。这种做法是here .我假设队列是一个生成器。 import rabbitp
我似乎无法运行代码 - 我一直在使用 Pika,并热衷于尝试这个线程安全且可能更简洁的版本。 import rabbitpy with rabbitpy.Connection('amqp://gues
我是一名优秀的程序员,十分优秀!