RabbitMQ的安装和使用Python连接RabbitMQ

绪论


这里的环境使用的是Mac OS X系统,所有的配置和使用都是基于Mac OS X 和Python 2.7 以及对应的pika库的。

RabbitMQ的安装和配置


安装部分

#brew install rabbitmq

配置和启动

#sudo brew services start rabbitmq
#sudo rabbitmqctl add_user admin admin                                   "创建用户(username  password)"
#sudo rabbitmqctl set_user_tags admin administrator                  "配置用户为超级管理员"
#sudo rabbitmqctl  set_permissions  -p  '/'  admin '.' '.' '.'            " 配置权限"
#sudo brew services restart rabbitmq                             

Python 与 pika


安装pika

#sudo pip install pika

Python与RabbitMQ的配合(基础)

# -*- coding:utf-8 -*-

import pika

class RabbitMQ(object):
    """一个简单的RabbitMQ的库,为了学习pika库"""
    def __init__(self,host='127.0.0.1',port=5672,username=None,password=None):
        """
            创建RabbitMQ的一个简单连接发起对象,参数如下
            (1)配置host,也就是RabbitMQ的IP地址.默认是127.0.0.1;
            (2)配置port,也就是RabbitMQ的端口信息,默认是5672;
            (3)可以配置用户名username、口令password,默认是None。
        """
        if username != None and password != None:
            try:
                self.Credentials = pika.PlainCredentials(username,password)#创建认证信息对象
                self.ConnectionKeys = pika.ConnectionParameters(host,port,'/',self.Credentials)#根据认证信息对象创建连接函数参数
            except Exception:
                raise
        else:
            self.ConnectionKeys = None
    def _connection(self):
        """发起连接的函数"""
        try:
            if self.ConnectionKeys == None:
                self.connection = pika.BlockingConnection()#无配置信息的连接
            else:
                self.connection = pika.BlockingConnection(self.ConnectionKeys)#有配置信息的连接
        except Exception:
            raise
    def _channel(self):
        """创建频道(游标)的函数"""
        self.channel = self.connection.channel()#创建频道(游标)
    def _callback(channel,method,properties,body):
        """callback函数,返回body体"""
        print "[+] Received Message:%s"%body
    def connect(self):
        """实例调用的连接接口"""
        self._connection()
        self._channel()
    def create_queque(slef,flag,durableflag=False):
        """创建一个新队列,flag是队列名称,durablflag是是否永久化的标志位,True表示永久化,False表示不是永久化"""
        try:
            self.channel.queue_declare(queue=flag,durable=durableflag)#创建新的消息队列
        except Exception:
            raise
    def set_queue_number(count):
        try:
            self.channel.basic_qos(prefetch_count=count)#每个worker每次count个消息
        except Exception:
            raise
    def commit(self):
        """确认函数"""
        try:
            self.channel.basic_ack(delivery_tag=method.delivery_tag)#回发确认报文
        except Exception:
            raise
    def
    def product(self,flag,content,exchange=''):
        """生产消息,flag是消息队列名称,content是消息队列内容"""
        try:
            self.channel.basic_publish(exchange='',routing_key=flag,body=content)#发送消息进入消息队列
        except Exception:
            raise
    def consume(slef,funcname=self._callback,flag,ackflag):
        """消费消息,flag是队列名称,ackflag是no_ack的标志位,True代表消息确认关闭"""
        """
            消息确认,是指在consumer收到一个消息但是还没有处理完成就死掉了的情况下,这个消息会回到消息队列里;
        """
        try:
            self.channel.basic_consume(callback=funcname,queue=flag,no_ack=ackflag)#从队列获取消息
        except Exception:
            raise
    def close(self):
        """关闭连接"""
        try:
            self.connection.close()#关闭连接
        except Exception:
            raise

转载于:https://www.cnblogs.com/KevinGeorge/p/9072632.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值