1.消息确认消费

1. 生产者端发消息时,加参数
properties=pika.BasicProperties(
delivery_mode=2, # make message persistent
), 2. 消费者端,消息处理完毕时,发送确认包
ch.basic_ack(delivery_tag=method.delivery_tag) 生产者端:
import pika credentials = pika.PlainCredentials('qqc', '123') parameters = pika.ConnectionParameters(host='127.0.0.1',credentials=credentials)
connection = pika.BlockingConnection(parameters) channel = connection.channel() #队列连接通道 #声明queue
channel.queue_declare(queue='hello_one',durable=True ) # durable==True 队列持久化 channel.basic_publish(exchange='',
routing_key='hello_one', #路由
properties = pika.BasicProperties (
delivery_mode= 2 , # 将消息持久化
),
body='Hello World') print(" [x] Sent 'Hello World!'") connection.close() 消费者端:
import pika
import time credentials = pika.PlainCredentials ('qqc','123') parameters = pika.ConnectionParameters (host='localhost',credentials =credentials )
connection = pika.BlockingConnection (parameters ) # 队列连接通道
channel = connection .channel() def callback(ch,method,properties,body):
'''
:param ch: 通道
:param method: 请求方法
:param properties: 消息参数
:param body: 消息内容
:return:
'''
print("[x] received %r" % body,method )
time.sleep(10)
print('msg handle done...',body) # 消费者处理完毕向服务端返回确认包,清除队列消息
ch.basic_ack(delivery_tag= method .delivery_tag) # 取信息
channel.basic_consume('hello_one',
callback, # 取到消息后调用callback
#no_ack=True # 消息处理后,不向rabbit-server确认消息已消费完毕
)
print('[*] waiting for messages. To exit press CTRL+C') # 阻塞模式
channel .start_consuming()

2. 公平分发

消费者端
channel.basic_qos(prefetch_count=1) 代码:
import pika
import time credentials = pika.PlainCredentials ('qqc','123') parameters = pika.ConnectionParameters (host='localhost',credentials =credentials )
connection = pika.BlockingConnection (parameters ) # 队列连接通道
channel = connection .channel() def callback(ch,method,properties,body):
'''
:param ch: 通道
:param method: 请求方法
:param properties: 消息参数
:param body: 消息内容
:return:
'''
print("[x] received %r" % body,method )
# time.sleep(10)
print('msg handle done...',body) # 消费者处理完毕向服务端返回确认包,清除队列消息
ch.basic_ack(delivery_tag= method .delivery_tag) # 公平分发
channel.basic_qos(prefetch_count=1) # 取信息
channel.basic_consume('hello_one',
callback, # 取到消息后调用callback
#no_ack=True # 消息处理后,不向rabbit-server确认消息已消费完毕
)
print('[*] waiting for messages. To exit press CTRL+C') # 阻塞模式
channel .start_consuming()

3. exchange

exchange type
fanout = 广播
direct = 组播
topic = 规则播
header =

3.1 fanout

生产者:
import pika
import sys
credentials = pika.PlainCredentials('qqc', '123') parameters = pika.ConnectionParameters(host='127.0.0.1',credentials=credentials)
connection = pika.BlockingConnection(parameters) channel = connection.channel() #队列连接通道 channel .exchange_declare(exchange= 'logs',exchange_type='fanout') message = ' '.join(sys.argv[1:]) or "info: Hello world" # 打印跟的参数 # 绑定exchange的所有队列都收到消息
channel .basic_publish(exchange= 'logs',
routing_key= '',
body =message )
print(" [x] Sent %r" % message) connection.close() '''
微博应用
发一个动态,关注的好友被推送,没有登陆的好友不推送
''' 消费者:
import pika
import time credentials = pika.PlainCredentials ('qqc','123') parameters = pika.ConnectionParameters (host='localhost',credentials =credentials )
connection = pika.BlockingConnection (parameters ) # 队列连接通道
channel = connection .channel() channel .exchange_declare(exchange='logs',exchange_type='fanout') #不指定queue名字,rabbit会随机分配一个名字
# exclusive=True会在使用此queue的消费者断开后,自动将queue删除
queue_obj = channel .queue_declare(queue='',exclusive= True) queue_name = queue_obj .method.queue
print('queue name',queue_name,queue_obj ) # 绑定队列都exchange
channel .queue_bind(exchange= 'logs',queue=queue_name) print(' [*] Waiting for logs. To exit press CTRL+C') def callback(ch,method,properties,body):
print(body) # 阻塞模式
channel .start_consuming()

3.2 direct

发布者:
import pika
import sys
credentials = pika.PlainCredentials('qqc', '123') parameters = pika.ConnectionParameters(host='127.0.0.1',credentials=credentials)
connection = pika.BlockingConnection(parameters) channel = connection.channel() #队列连接通道 channel .exchange_declare(exchange= 'direct_logs',exchange_type='direct') log_level =sys.argv[1] if len(sys.argv)> 1 else 'info'
message = ' '.join(sys.argv[1:]) or "info: Hello world" # 打印跟的参数 channel .basic_publish(exchange= 'logs',
routing_key= log_level ,
body =message )
print(" [x] Sent %r" % message) connection.close() # python3 P_direct.py info hello 在info上发消息 订阅者:
import pika
import time
import sys
credentials = pika.PlainCredentials ('qqc','123') parameters = pika.ConnectionParameters (host='localhost',credentials =credentials )
connection = pika.BlockingConnection (parameters ) # 队列连接通道
channel = connection .channel() channel .exchange_declare(exchange='logs',exchange_type='fanout') #不指定queue名字,rabbit会随机分配一个名字
# exclusive=True会在使用此queue的消费者断开后,自动将queue删除
queue_obj = channel .queue_declare(queue='',exclusive= True) queue_name = queue_obj .method.queue
print('queue name',queue_name,queue_obj ) log_levels = sys.argv[1:] if not log_levels :
sys.stderr .write("Usage: %s [info] [warning] [error]\n" % sys.argv[0])
sys.exit() for level in log_levels :
channel.queue_bind(exchange='logs',
queue=queue_name,
routing_key= level) # 绑定队列到exchange print(' [*] Waiting for logs. To exit press CTRL+C') def callback(ch,method,properties,body):
print(body) channel .basic_consume(queue_name, callback) # 阻塞模式
channel .start_consuming() '''
发布订阅模式
绑定且在线才能收到
''' # python3 .\C_direct.py info 接收info上的消息

3.3 topic

发布者:
import pika
import sys credentials = pika.PlainCredentials('qqc', '123') parameters = pika.ConnectionParameters(host='127.0.0.1',credentials=credentials)
connection = pika.BlockingConnection(parameters) channel = connection .channel() channel.exchange_declare(exchange= 'topic_log',exchange_type='topic') log_level = sys.argv[1] if len(sys.argv) >1 else 'all.info' message = ' '.join(sys.argv[1:]) or 'all.info:Hello World' channel .basic_publish(exchange='topic_log',
routing_key= log_level ,
body = message)
print("[x] Sent %r" %message)
connection .close() 订阅着:
import pika,sys
credentials = pika.PlainCredentials('qqc', '123') parameters = pika.ConnectionParameters(host='127.0.0.1',credentials=credentials)
connection = pika.BlockingConnection(parameters) channel = connection.channel() #队列连接通道
queue_obj = channel .queue_declare(queue = '',exclusive= True )
queue_name = queue_obj.method.queue log_levels = sys.argv[1:] if not log_levels :
sys.stderr .write("User: %s [info] [warning] [error]\n" % sys.argv[0]) for level in log_levels :
channel .queue_bind(exchange= 'topic_log',
queue = queue_name ,
routing_key= level)
print('[*] Waiting for logs.To exit press CTRL+C') def callback(ch,method,properties,body):
print("[x] %r" %body) channel .basic_consume(queue_name ,callback )
channel .start_consuming() 测试:
发布者:
python3 P_topic.py i.mysql.error tttttt 订阅者:
python3 C_topic.py *.mysql.error

4. RPC

RabbitMQ使用(二)的更多相关文章

  1. RabbitMQ(二)

    一.启用 rabbitmq_management 插件(官网提供的 web 版管理工具) cd /usr/sbin rabbitmq-plugins enable rabbitmq_managemen ...

  2. 消息队列的使用 RabbitMQ (二): Windows 环境下集群的实现

    一.RabbitMQ 集群的基本概念 一个 RabbitMQ 中间件(broker) 由一个或多个 erlang 节点组成,节点之间共享 用户名.虚拟目录.队列消息.运行参数 等, 这个 节点的集合被 ...

  3. SpringBoot集成rabbitmq(二)

    前言 在使用rabbitmq时,我们可以通过消息持久化来解决服务器因异常崩溃而造成的消息丢失.除此之外,我们还会遇到一个问题,当消息生产者发消息发送出去后,消息到底有没有正确到达服务器呢?如果不进行特 ...

  4. python使用rabbitMQ介绍二(工作队列模式)

    一模式介绍 第一章节的生产-消费者模式,是非常简单的模式,一发一收.在实际的应用中,消费者有的时候需要工作较长的时间,则需要增加消费者. 队列模型: 这时mq实现了一下几个功能: rabbitmq循环 ...

  5. RabbitMQ (十二) 消息确认机制 - 发布者确认

    消费者确认解决的问题是确认消息是否被消费者"成功消费". 它有个前提条件,那就是生产者发布的消息已经"成功"发送出去了. 因此还需要一个机制来告诉生产者,你发送 ...

  6. Rabbitmq笔记二

    消息何去何从 mandatory 和 immediate 是 channel . basicPublish 方法中的两个参数,它们都有 当消息传递过程中不可达目的地时将消息返回给生产者的功能. 当 m ...

  7. RabbitMQ系列(二)--基础组件

    声明:对于RabbitMQ的学习基于某课网相关视频和<RabbitMQ实战指南>一书,后续关于RabbitMQ的博客都是基于二者 一.什么是RabbitMQ RabbitMQ是开源代理和队 ...

  8. RabbitMq应用二

    在应用一中,基本的消息队列使用已经完成了,在实际项目中,一定会出现各种各样的需求和问题,rabbitmq内置的很多强大机制和功能会帮助我们解决很多的问题,下面就一个一个的一起学习一下. 消息响应机制 ...

  9. RabbitMQ(二) -- Work Queues

    RabbitMQ(一) -- Work Queues RabbitMQ使用Work Queues的主要目的是为了避免资源使用密集的任务,它不同于定时任务处理的方式,而是把任务封装为消息添加到队列中.而 ...

  10. RabbitMQ系列二(构建消息队列)

    从AMQP协议可以看出,MessageQueue.Exchange和Binding构成了AMQP协议的核心.下面我们就围绕这三个主要组件,从应用使用的角度全面的介绍如何利用RabbitMQ构建消息队列 ...

随机推荐

  1. mysql数据权限操作

    1.创建新用户 通过root用户登录之后创建 >> grant all privileges on *.* to testuser@localhost identified by &quo ...

  2. vue消息提示Message

    https://www.iviewui.com/components/message this.$Message.info(config) this.$Message.success(config) ...

  3. PHP定时任务实现(计划任务 vs node.js)

    PHP自动任务(单线程) 一.计划任务实现 :最终需要在服务器(windows)上 设置计划任务 1.写好php任务文件 auto.php:链接数据库 判断条件操作数据库 2.创建bat文件 例:ru ...

  4. CPython,PyPy?Python和这两个东西有什么关系

    https://blog.csdn.net/fu6543210/article/details/90770794 python是一种编程语言.但这种语言有多种实现,而且与其他语言不同,python并没 ...

  5. 【Java多线程系列七】ExecutorService

    java.util.concurrent.ExecutorService接口提供了许多线程管理的方法 Method 说明 shutdown 拒绝接收新的任务,待已提交的任务执行后关闭,且宿主线程不阻塞 ...

  6. Java语言基础及java核心

    一.Java语言特点 1. 简单 2. 面向对象 3. 分布式 4. 健壮 5. 安全 6. 中性架构跨平台 7. 超强的可移植性 8. 高性能 9. 多线程 二.java的环境变量 JAVA_HOM ...

  7. 二、检索语句 SELECT、ORDER BY、WHERE

    介绍如何使用SELECT语句从表中检索一个或多个数据列   第二章: SELECT语句 SQL语句可以在一行给出,也可以分成许多行,分成多行更容易调试. 多条SQL语句必须以分号 分隔.多数DBMS不 ...

  8. 使用org-mode写cnblogs博客

    使用org-mode写cnblogs博客 */--> pre.src {background-color: #002b36; color: #839496;} pre.src {backgrou ...

  9. WEB前端资源集

    原出处:http://www.cnblogs.com/zhengjialux/archive/2017/01/16/6291394.html 资源网站篇 CSDN:全球最大中文IT社区,为IT专业技术 ...

  10. BUUCTF RE部分题目wp

    RE 1,easyre拖进ida,得到flag 2,helloworld 将文件拖入apk改之理,得到flag 3,xor拖进ida,就是简单异或,写脚本 glo=[0x66,0x0a,0x6b,0x ...