Pika使用入门(一)【介绍】

介绍

Pika是AMQP 0-9-1协议的纯Python实现,试图保持与底层网络支持库相当独立。

 支持Python 2.6+和3.3+。
 由于线程不适合每一种情况,它不需要线程。 也不要禁止他们。 greenlets, callbacks, continuations and generators也是如此。 然而,它不一定是线程安全的,实际的结果可能会有些不同。。
 人们可能正在使用 direct sockets,普通的老的select(),或是从python应用程序获取网络事件的各种各样的方式。 Pika试图与所有这些保持兼容,并使其适应尽可能简单的新环境。

以下是最简单的使用示例,使用BlockingConnection适配器发送消息:

import pika

credentials = pika.PlainCredentials('wu','123456')
connection = pika.BlockingConnection(pika.ConnectionParameters('127.0.0.1',5672,'simple',credentials))
channel = connection.channel() #在连接上创建一个频道

channel.queue_declare(queue='pikamq') #声明一个队列,生产者和消费者都要声明一个相同的队列,用来防止万一某一方挂了,另一方能正常运行

channel.basic_publish(exchange='', #交换机
                      routing_key='pikamq',  # queue名字 #路由键,写明将消息发往哪个队列,本例是将消息发往队列pikamq
                      body='Test Message') # 消息内容
connection.close() #当生产者发送完消息后,可选择关闭连接

这里写图片描述


写一个blocking消费者的例子:

import pika
credentials = pika.PlainCredentials('wu','123456')
connection = pika.BlockingConnection(pika.ConnectionParameters('127.0.0.1',5672,'simple',credentials))
channel = connection.channel() #在连接上创建一个频道

channel.queue_declare(queue='pikamq') #声明一个队列,生产者和消费者都要声明一个相同的队列,用来防止万一某一方挂了,另一方能正常运行

for method_frame, properties, body in channel.consume('test'):

    #显示消息部分并确认消息
    print method_frame, properties, body
    channel.basic_ack(method_frame.delivery_tag)

    #在10条消息后退出循环
    if method_frame.delivery_tag == 10:
        break

#取消消费者并返回任何待处理消息
requeued_messages = channel.cancel()
print 'Requeued %i messages' % requeued_messages
connection.close()

这里写图片描述


Pika提供以下适配器

 BlockingConnection - 启用对库进行阻塞,同步操作以进行简单的使用
 LibevConnection - 用于libev事件循环http://libev.schmorp.de的适配器
 SelectConnection - 快速异步适配器
 TornadoConnection - 适用于Tornado IO Loop的适配器http://tornadoweb.org
 TwistedConnection - 用于Twisted异步包的适配器http://twistedmatrix.com/
  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值