异步方案Celery和RabbitMQ,安装和测试

学习目标:

  • 说明异步任务队列发送短信的步骤
  • 说明 celery 的组成部分及其作用

在这里插入图片描述

在这里插入图片描述

Celery介绍

celery是python开发的,基于分布式消息传递系统的异步任务队列
在这里插入图片描述

RabbitMQ介绍和使用

我的是在Windows上安装的,安装的博客介绍查看:
https://blog.csdn.net/zhm3023/article/details/82217222

安装好之后,需要注意的是,我们使用python连接测试,rabbit的server一定要打开,它是不会自己打开的,cmd中进入C:\Program Files\rabbitmq_server-3.7.7\sbin,使用这个命令打开服务在这里插入图片描述

在这里插入图片描述

打开之后:
在这里插入图片描述
然后在pycharm上进行测试:
我们新建了这个测试包 rabbit test:
在这里插入图片描述
在pycharm下还要安装一个包 叫做
在这里插入图片描述

还创建了生产者和消费者文件
代码如下:

producer.py:

import pika


# 链接到RabbitMQ服务器
credentials = pika.PlainCredentials('guest', 'guest')
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost',5672,'/',credentials))
#创建频道
channel = connection.channel()
# 声明消息队列
channel.queue_declare(queue='woniu')
# routing_key是队列名 body是要插入的内容
channel.basic_publish(exchange='', routing_key='woniu', body='Hello bt!')
print("开始向 'zxc' 队列中发布消息 'Hello RabbitMQ!'")
# 关闭链接
connection.close()

customer.py:

import pika


# 链接到rabbitmq服务器
credentials = pika.PlainCredentials('guest', 'guest')
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost',5672,'/',credentials))

# 创建频道,声明消息队列
channel = connection.channel()
channel.queue_declare(queue='woniu')

# 定义接受消息的回调函数
def callback(ch, method, properties, body):
    print(body.decode())

# 告诉RabbitMQ使用callback来接收信息
channel.basic_consume(on_message_callback=callback, queue='woniu', auto_ack=True)

# 开始接收信息
channel.start_consuming()

运行效果:
在produce中运行:
在这里插入图片描述
在customer中接收结果:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你在狗叫什么、

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值