学习目标:
- 说明异步任务队列发送短信的步骤
- 说明 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中接收结果: