1、rabbitMQ 与ptyhon 进程queue 区别。进程queue 主要用户Python父子进程之间或者统一进程不同子进程。rabbit可以用户不同语言之前的相互交流,socket可以实现同样功能,但是较为复杂。

2、 rabbitMQ  消息轮训。一个生产者对多个消费者时候。会自动将消息轮训给不同消费者。

# Author : xiajinqi

import pika

connetction = pika.BlockingConnection(pika.ConnectionParameters("localhost"))

channel = connetction.channel()

channel.queue_declare(queue='hello')
# 1个生产着,三个消费者,会自动轮训,其中一个消费者宕机后,消息会自动发给其他消费者处理。
channel.basic_publish(exchange='',routing_key='hello',body='hello world!') print("消息已经发送") channel.close() # Author : xiajinqi
import pika
import time connetction = pika.BlockingConnection(pika.ConnectionParameters("localhost")) channel = connetction.channel() channel.queue_declare(queue='hello') #避免生产者后启动,没有这个队列报错。所以在此申明 def callback(ch,method,properties,body):
'''
:param ch: 管道对象内存地址
:param method: 发消息给谁的申明信息
:param properties:
:param body:
:return:
'''
print(ch,method,properties,body)
ch.basic_ack(delivery_tag=method.delivery_tag) #执行完以后告诉服务端
# time.sleep()
pass ## 申明收到调用callbak处理 no_ack 默认为false消息不会丢失,表示需要客户端回调函数处理完,主动告诉服务端已经处理完。为true断电消息会丢失
#channel.basic_consume(callback,queue='hello',no_ack='True')
channel.basic_consume(callback,queue='hello') print("开始收消息") channel.start_consuming()

3、服务端消息持久化声明

channel.queue_declare(queue='hello1',durable='True') # durable队列持久化申明
# 1个生产着,三个消费者,会自动轮训,其中一个消费者宕机后,消息会自动发给其他消费者处理。
#delivery_mode 消息持久化声明
channel.basic_publish(exchange='',routing_key='hello1',body='hello world!',properties=pika.BasicProperties(delivery_mode=))

4、消息轮训,机器性能不同时候,可能要求每个机器权重不一样。实现机制如下。prefetch_count =1 只要有消息没有处理完。自动转化给其他人

# Author : xiajinqi
import pika
import time connetction = pika.BlockingConnection(pika.ConnectionParameters("localhost")) channel = connetction.channel() channel.queue_declare(queue='hello2',durable="True") #避免生产者后启动,没有这个队列报错。所以在此申明 def callback(ch,method,properties,body):
'''
:param ch: 管道对象内存地址
:param method: 发消息给谁的申明信息
:param properties:
:param body:
:return:
'''
print(ch,method,properties,body)
ch.basic_ack(delivery_tag=method.delivery_tag) #执行完以后告诉服务端
# time.sleep(30)
pass #channel.basic_consume(callback,queue='hello',no_ack='True')
channel.basic_consume(callback,queue='hello2') channel.basic_qos(prefetch_count=1)
print("开始收消息") channel.start_consuming()

5、exchange 中的fanout模式,广播模式。服务端生成一个交换器exchange(广播台开始广播)。客户端每次随机生成一个队列(收音机)。然后绑定exchange。

广播模式中。会发给所有绑定exchange的队列。消息不会缓存。类似于广播。消息是实时的。即广播时候。用户不在消息不缓存。用户不在线。消息依旧发送

# Author : xiajinqi

import pika

connetction = pika.BlockingConnection(pika.ConnectionParameters("localhost"))

channel = connetction.channel()

#channel.queue_declare(queue='hello1',durable='True') #
channel.exchange_declare(exchange='logs',exchange_type='fanout') channel.basic_publish(exchange='logs',routing_key='',body='hello world!',properties=pika.BasicProperties(delivery_mode=)) print("消息已经发送") channel.close()
#E:\RB\rabbitmq_server-3.7.\sbin\rabbitmqctl.bat list_queues # Author : xiajinqi
import pika
import time connetction = pika.BlockingConnection(pika.ConnectionParameters("localhost")) channel = connetction.channel() #channel.queue_declare(queue='hello2',durable="True") #避免生产者后启动,没有这个队列报错。所以在此申明 channel.exchange_declare(exchange='logs',exchange_type='fanout') result = channel.queue_declare(exclusive='True') #客户端每次启动会随机生成一个队列
queue_name = result.method.queue # 获取随机生成的队列名 # exchange 绑定 queue
channel.queue_bind(exchange='logs',queue=queue_name) def callback(ch,method,properties,body):
'''
:param ch: 管道对象内存地址
:param method: 发消息给谁的申明信息
:param properties:
:param body:
:return:
'''
print(ch,method,properties,body)
ch.basic_ack(delivery_tag=method.delivery_tag) #执行完以后告诉服务端
# time.sleep()
pass ## 申明收到调用callbak处理 no_ack 默认为false消息不会丢失,表示需要客户端回调函数处理完,主动告诉服务端已经处理完。为true断电消息会丢失
#channel.basic_consume(callback,queue='hello',no_ack='True')
channel.basic_consume(callback,queue=queue_name) channel.basic_qos(prefetch_count=)
print("开始收消息") channel.start_consuming()

6、direct 模式。

# Author : xiajinqi

import pika
import sys
connetction = pika.BlockingConnection(pika.ConnectionParameters("localhost")) channel = connetction.channel() #channel.queue_declare(queue='hello1',durable='True') #
channel.exchange_declare(exchange='direct_logs',exchange_type='direct') serverity = sys.argv[] if len(sys.argv)> else 'info'
message = ''.join(sys.argv[:]) or 'hello world' channel.basic_publish(exchange='direct_logs',routing_key=serverity,body=message,properties=pika.BasicProperties(delivery_mode=)) print("消息已经发送") channel.close() # Author : xiajinqi
import pika
import time
import sys
connetction = pika.BlockingConnection(pika.ConnectionParameters("localhost")) channel = connetction.channel() #channel.queue_declare(queue='hello2',durable="True") #避免生产者后启动,没有这个队列报错。所以在此申明 channel.exchange_declare(exchange='direct_logs',exchange_type='direct') result = channel.queue_declare(exclusive='True') #客户端每次启动会随机生成一个队列 channel.exchange_declare(exchange='direct_logs',exchange_type='direct') serverity = sys.argv[:] if not serverity:
print("退出")
sys.exit() queue_name = result.method.queue # 获取随机生成的队列名 for st in serverity:
channel.queue_bind(exchange='direct_logs', queue=queue_name,routing_key=st) def callback(ch,method,properties,body):
'''
:param ch: 管道对象内存地址
:param method: 发消息给谁的申明信息
:param properties:
:param body:
:return:
'''
print(ch,method,properties,body)
ch.basic_ack(delivery_tag=method.delivery_tag) #执行完以后告诉服务端
# time.sleep()
pass ## 申明收到调用callbak处理 no_ack 默认为false消息不会丢失,表示需要客户端回调函数处理完,主动告诉服务端已经处理完。为true断电消息会丢失
#channel.basic_consume(callback,queue='hello',no_ack='True')
channel.basic_consume(callback,queue=queue_name) channel.basic_qos(prefetch_count=)
print("开始收消息") channel.start_consuming()

7、topic 模式 和 direct 可以动态匹配

# Author : xiajinqi

import pika
import sys
connetction = pika.BlockingConnection(pika.ConnectionParameters("localhost")) channel = connetction.channel() #channel.queue_declare(queue='hello1',durable='True') #
channel.exchange_declare(exchange='direct_logs',exchange_type='topic') serverity = sys.argv[] if len(sys.argv)> else 'info'
message = ''.join(sys.argv[:]) or 'hello world' channel.basic_publish(exchange='direct_logs',routing_key=serverity,body=message,properties=pika.BasicProperties(delivery_mode=)) print("消息已经发送") channel.close()

8、

  

python 消息队列-rabbitMQ 和 redis介绍使用的更多相关文章

  1. 架构设计之NodeJS操作消息队列RabbitMQ

    一. 什么是消息队列? 消息(Message)是指在应用间传送的数据.消息可以非常简单,比如只包含文本字符串,也可以更复杂,可能包含嵌入对象. 消息队列(Message Queue)是一种应用间的通信 ...

  2. python消息队列snakemq使用总结

    Python 消息队列snakemq总结 最近学习消息总线zeromq,在网上搜了python实现的消息总线模块,意外发现有个消息队列snakemq,于是拿来研究一下,感觉还是很不错的,入手简单使用也 ...

  3. 高性能消息队列 CKafka 核心原理介绍(上)

    欢迎大家前往腾讯云技术社区,获取更多腾讯海量技术实践干货哦~ 作者:闫燕飞 1.背景 Ckafka是基础架构部开发的高性能.高可用消息中间件,其主要用于消息传输.网站活动追踪.运营监控.日志聚合.流式 ...

  4. Python消息队列工具 Python-rq 中文教程

    原创文章,作者:Damon付,如若转载,请注明出处:<Python消息队列工具 Python-rq 中文教程>http://www.tiangr.com/python-xiao-xi-du ...

  5. 消息队列--RabbitMQ(一)

    1.消息队列概述 可以理解为保存消息的一个媒介/或者是个容器,与之相关有两个概念(即生产者(Publish)与消费者(Consumer)).所谓生产者,就是生产创造消息的一方,那么,消费者便是从队列中 ...

  6. (二)RabbitMQ消息队列-RabbitMQ消息队列架构与基本概念

    原文:(二)RabbitMQ消息队列-RabbitMQ消息队列架构与基本概念 没错我还是没有讲怎么安装和写一个HelloWord,不过快了,这一章我们先了解下RabbitMQ的基本概念. Rabbit ...

  7. ASP.NET Core消息队列RabbitMQ基础入门实战演练

    一.课程介绍 人生苦短,我用.NET Core!消息队列RabbitMQ大家相比都不陌生,本次分享课程阿笨将给大家分享一下在一般项目中99%都会用到的消息队列MQ的一个实战业务运用场景.本次分享课程不 ...

  8. 消息队列rabbitmq/kafka

    12.1 rabbitMQ 1. 你了解的消息队列 rabbitmq是一个消息代理,它接收和转发消息,可以理解为是生活的邮局.你可以将邮件放在邮箱里,你可以确定有邮递员会发送邮件给收件人.概括:rab ...

  9. 消息队列rabbitmq rabbitMQ安装

    消息队列rabbitmq   12.1 rabbitMQ 1. 你了解的消息队列 生活里的消息队列,如同邮局的邮箱, 如果没邮箱的话, 邮件必须找到邮件那个人,递给他,才玩完成,那这个任务会处理的很麻 ...

随机推荐

  1. laravel with嵌套的渴求式加载

    今天在通过需求表A查询场地类型表B,然后通过表B的场地类型id去查询表C场地类型名的时候遇到了一个小的问题. 需求表A的字段:id.user_id .name等等: 中间表B的字段:id.appeal ...

  2. EXCHANGE 2013 队列

    每当咱在Exchange里查看队列的时候,我们会看到队列分成好几个组,每个邮箱数据库都有自己的目标队列,DAG.AD站点也是,AD林也是一个队列,最后最多的就是外部SMTP域队列. 当传输服务处理队列 ...

  3. 乘风破浪:LeetCode真题_018_4Sum

    乘风破浪:LeetCode真题_018_4Sum 一.前言 前面我们已经练习过了三个数相加的集合运算,现在变成了四个数,其实道理是一样的.三个数的时候可以转成两个数的加法,最后来解决,而四个数的可以转 ...

  4. ZT 打工者买彩票中1000万 5年后变逃犯身上剩80元

    打工者买彩票中1000万 5年后变逃犯身上剩80元   2014-01-07 08:22 来源:都市快报 我有话说 挥霍—— 从800万到80元 在湖南永州零陵区富家桥镇茶叶湾村,陈某是不折不扣的名人 ...

  5. ZT 分智网博客 – 职场、面试技巧、职业规划

    http://blog.fenzhi.com/archives/5148.html 分智网博客 – 职场.面试技巧.职业规划 软件工程师职位薪酬最高的25家中国公司 作者: 分智网 日期: 2013 ...

  6. scala集合与数据结构

    1.数据结构特点 Scala同时支持可变集合和不可变集合,不可变集合从不可变,可以安全的并发访问. 两个主要的包: 不可变集合:scala.collection.immutable 可变集合: sca ...

  7. 为什么JS中0.1+0.2 != 0.3

    为什么JS中0.1+0.2 != 0.3 在我曾经的一篇< javascript入门教程 (2) >中,讲到JS中数字运算时,我们提到过一个叫做 数字运算中的精度缺失的问题,当时我们只是简 ...

  8. (转)Win10下PostgreSQL10与PostGIS安装

    版权声明:本文为博主原创文章,欢迎转载. https://blog.csdn.net/LWJ285149763/article/details/79380643 最近在使用矢量数据,因此需要用空间数据 ...

  9. 《metasploit渗透测试魔鬼训练营》学习笔记第三章----情报搜集

    Kali渗透测试系统集成了metasploit开源的漏洞测试框架,是渗透测试必备的神器.下面是我在学习metasploit的笔记,有什么错误的地方请指出来,我会立即纠正的~ 一.情报搜集     1. ...

  10. js中this应用

    this是js的一个关键字,随着函数使用场合不同,this的值会发生变化.但是总有一个原则,那就是this指的是调用函数的那个对象. 1.纯粹函数调用. function test() { this. ...