python rabbitMq producer/consumer 使用实例

1,安装pika库
yum -y install epel-release
 yum -y install python-pip
 pip install --upgrade pip
  pip install pika
  2,rabbitMq.py

#!/bin/python2
#coding=utf-8

import pika
import uuid
import sys

class RabbitMQ(object):
    def __init__(self,addr,rabbitMqName):
        self.mqAddr =addr
        self.msgQueueName = rabbitMqName
    def msg_on_recv(self, ch, mothod, properties, msg):
        print("[Consumer] recv %s" % msg)

    def msg_start(self):
        print("[Consumer] waiting for msg")

        self.mqParam = pika.URLParameters(self.mqAddr)

        try:
            self.connection = pika.BlockingConnection(self.mqParam)

            self.channel = self.connection.channel()
            self.channel.queue_declare(queue=self.msgQueueName)
            self.channel.basic_consume(self.msgQueueName,self.msg_on_recv)

            self.channel.start_consuming()
        except pika.exceptions.AMQPError as e:
            print('AMQPError {0} , {1}'.format(self.mqAddr, e))
    def msg_send(self, msg):
        print("[Producer] send %s" % msg)
        self.mqParam = pika.URLParameters(self.mqAddr)

        try:
            self.connection = pika.BlockingConnection(self.mqParam)

            self.channel = self.connection.channel()
            self.channel.queue_declare(queue=self.msgQueueName)

            self.channel.basic_publish(exchange='', routing_key=self.msgQueueName, body=msg)
        except pika.exceptions.AMQPError as e:
            print('AMQPError {0} , {1}'.format(self.mqAddr, e))

3,调用实例

rabbitMqProducer.py

请把address换成你的rabbitMq的地址

from rabbitMq import *

obj = RabbitMQ("address",'my_queue')
obj.msg_send('hello world')

 

[dev@test-ba-node-004 python]$ cat rabbitMqConsumer.py 请把address换成你的raddbitMq的地址

from rabbitMq import *

obj = RabbitMQ("address",'my_queue')
obj.msg_start()

4,运行结果:

[dev@test-ba-node-004 python]$ python rabbitMqProducer.py 
[Producer] send hello world
[dev@test-ba-node-004 python]$ python rabbitMqConsumer.py 
[Consumer] waiting for msg
[Consumer] recv hello world

5,踩的坑

self.channel.basic_consume(self.msgQueueName,self.msg_on_recv)

这个函数的顺序变过,旧的函数为callback函数在前,queue在后,新的换顺序了,所以这个函数的使用跟版本有关

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值