RabbitMQ、Rdis
RabbitMQ
RabbitMQ:官方网址:http://www.rabbitmq.com/
Install Erlang
# rpm -ivh erlang-18.3-1.el6.x86_64.rpm
Install RabbitMQ Server
rpm -ivh rabbitmq-server-3.6.2-1.noarch.rpm

1、Hello World!

生产者
import pika
credentials = pika.PlainCredentials('guest', 'guest') # 使用用户名密码进行验证
connection = pika.BlockingConnection(
pika.ConnectionParameters(host='192.168.33.35', port=5672, credentials=credentials))
channel = connection.channel() # 声明一个通道
channel.queue_declare(queue='test.queue') # 声明一个queue
channel.basic_publish(exchange='', routing_key='test.queue', body='Hello World!')
print(" [x] Sent 'Hello World!'")
connection.close()
消费者
import pika
credentials = pika.PlainCredentials('guest', 'guest') # 使用用户名密码进行验证
connection = pika.BlockingConnection(
pika.ConnectionParameters(host='192.168.33.35', port=5672, credentials=credentials))
channel = connection.channel()
channel.queue_declare(queue='test.queue')
def callback(ch, method, properties, body):
print(" [x] Received %r" % body)
channel.basic_consume(callback, queue='test.queue', no_ack=True) # callback如果收到消息就调用callback函数处理消息
# no_ack=True 指客户端处理完消息后,不跟服务器进行确认,这个参数在生成一定不能是用
channel.basic_qos(prefetch_count=1) # 设置接收端控制消息处理机制
print(' [*] Waiting for messages. To exit press CTRL+C')
channel.start_consuming()
acknowledgments
Message acknowledgments are turned on by default,在前面的代码内,我们为了举例,no_ack=True,这个参数在生产环境强烈建议去掉。
下面展示一段消费者代码:
import pika
credentials = pika.PlainCredentials('guest', 'guest') # 使用用户名密码进行验证
connection = pika.BlockingConnection(
pika.ConnectionParameters(host='192.168.33.35', port=5672, credentials=credentials))
channel = connection.channel()
channel.queue_declare(queue='test.queue', durable=True)
def callback(ch, method, properties, body):
print(" [x] Received %r" % body)
ch.basic_ack(delivery_tag=method.delivery_tag) # 代表告诉消息服务器我处理完毕,你可以把消息删除了
channel.basic_consume(callback, queue='test.queue') # callback如果收到消息就调用callback函数处理消息
channel.basic_qos(prefetch_count=1) # 设置接收端控制消息处理机制
print(' [*] Waiting for messages. To exit press CTRL+C')
channel.start_consuming()
消息的持久化
First, we need to make sure that RabbitMQ will never lose our queue. In order to do so, we need to declare it as durable:
channel.queue_declare(queue='hello', durable=True)
This queue_declare change needs to be applied to both the producer and consumer code.
Now we need to mark our messages as persistent - by supplying a delivery_mode property with a value 2.
channel.basic_publish(exchange='',
routing_key="task_queue",
body=message,
properties=pika.BasicProperties(
delivery_mode = 2, # make message persistent
))
例1:
import pika
credentials = pika.PlainCredentials('guest', 'guest') # 使用用户名密码进行验证
connection = pika.BlockingConnection(
pika.ConnectionParameters(host='192.168.33.35', port=5672, credentials=credentials))
channel = connection.channel() # 声明一个通道
channel.queue_declare(queue='test.queue', durable=True) # 声明一个queue
properties = pika.BasicProperties(delivery_mode=2) # 消息持久化
channel.basic_publish(exchange='', routing_key='test.queue', body='Hello World!', properties=properties)
print(" [x] Sent 'Hello World!'")
connection.close()
消息发布\订阅
Exchange在定义的时候是有类型的,以决定到底是哪些Queue符合条件,可以接收消息
fanout: 所有bind到此exchange的queue都可以接收消息
direct: 通过routingKey和exchange决定的那个唯一的queue可以接收消息
topic:所有符合routingKey(此时可以是一个表达式)的routingKey所bind的queue可以接收消息
注意:消息不会存在Exchange里面。
exchange type=fanout

生产者:
import pika
import sys credentials = pika.PlainCredentials('guest', 'guest') # 使用用户名密码进行验证
connection = pika.BlockingConnection(
pika.ConnectionParameters(host='192.168.33.35', port=5672, credentials=credentials))
channel = connection.channel() channel.exchange_declare(exchange='logs', type='fanout', durable=True) message = ' '.join(sys.argv[1:]) or "info: Hello Worlcccc!" channel.basic_publish(exchange='logs', routing_key='', body=message)
print(" [x] Sent %r" % message)
connection.close()
消费者:
import pika
credentials = pika.PlainCredentials('guest', 'guest') # 使用用户名密码进行验证
connection = pika.BlockingConnection(
pika.ConnectionParameters(host='192.168.33.35', port=5672, credentials=credentials))
channel = connection.channel()
channel.exchange_declare(exchange='logs', type='fanout', durable=True)
result = channel.queue_declare(exclusive=True) # 不指定queue名字,rabbit会随机分配一个名字,exclusive=True会在使用此queue的消费者断开后,自动将queue删除
queue_name = result.method.queue
channel.queue_bind(exchange='logs', queue=queue_name)
print(' [*] Waiting for logs. To exit press CTRL+C')
def callback(ch, method, properties, body):
print(" [x] %r" % body)
channel.basic_consume(callback, queue=queue_name)
channel.start_consuming()
exchange type=direct
RabbitMQ还支持根据关键字发送,即:队列绑定关键字,发送者将数据根据关键字发送到消息exchange,exchange根据 关键字 判定应该将数据发送至指定队列。

生产者
import pika
import sys credentials = pika.PlainCredentials('guest', 'guest')
connection = pika.BlockingConnection(
pika.ConnectionParameters(host='192.168.33.35', port=5672, credentials=credentials))
channel = connection.channel() channel.exchange_declare(exchange='direct_logs', type='direct') severity = sys.argv[1] if len(sys.argv) > 1 else 'info' message = ' '.join(sys.argv[2:]) or 'Hello World!' channel.basic_publish(exchange='direct_logs', routing_key=severity, body=message)
print(" [x] Sent %r:%r" % (severity, message))
connection.close()
消费者
import pika
import sys credentials = pika.PlainCredentials('guest', 'guest')
connection = pika.BlockingConnection(
pika.ConnectionParameters(host='192.168.33.35', port=5672, credentials=credentials))
channel = connection.channel() channel.exchange_declare(exchange='direct_logs', type='direct') result = channel.queue_declare(exclusive=True)
queue_name = result.method.queue severities = sys.argv[1:]
if not severities:
sys.stderr.write("Usage: %s [info] [warning] [error]\n" % sys.argv[0])
sys.exit(1) for severity in severities:
channel.queue_bind(exchange='direct_logs', queue=queue_name, routing_key=severity) print(' [*] Waiting for logs. To exit press CTRL+C') def callback(ch, method, properties, body):
print(" [x] %r:%r" % (method.routing_key, body)) channel.basic_consume(callback, queue=queue_name) channel.start_consuming()
exchange type=topic

生产者:
消费者:
#:代表接收所有消息
Remote procedure call (RPC)
RabbitMQ常用命令:
列出所有queue,The default value is "/"
1、rabbitmqctl list_queues
修改用户的密码
2、change_password <username> <newpassword>
Redis
Redis是缓存数据库,
import redis r = redis.Redis(host='192.168.33.35', port=6379)
r.set('foo', 'Bar')
print(r.get('foo'))
连接池方式:
import redis pool = redis.ConnectionPool(host='192.168.33.35', port=6379) r = redis.Redis(connection_pool=pool)
r.set('foo', 'Bar')
print(r.get('foo'))
set(name, value, ex=None, px=None, nx=False, xx=False)
在Redis中设置值,默认,不存在则创建,存在则修改
参数: ex,过期时间(秒) px,过期时间(毫秒) nx,如果设置为True,则只有name不存在时,当前set操作才执行 xx,如果设置为True,则只有name存在时,岗前set操作才执行Redis常用命令介绍
RabbitMQ、Rdis的更多相关文章
- Kafka、RabbitMQ、RocketMQ消息中间件的对比 —— 消息发送性能-转自阿里中间件
引言 分布式系统中,我们广泛运用消息中间件进行系统间的数据交换,便于异步解耦.现在开源的消息中间件有很多,前段时间我们自家的产品 RocketMQ (MetaQ的内核) 也顺利开源,得到大家的关注. ...
- Python操作Redis、Memcache、RabbitMQ、SQLAlchemy
Python操作 Redis.Memcache.RabbitMQ.SQLAlchemy redis介绍:redis是一个开源的,先进的KEY-VALUE存储,它通常被称为数据结构服务器,因为键可以包含 ...
- RabbitMq、ActiveMq、ZeroMq 和 kafka 比较
MQ框架非常之多,比较流行的有RabbitMq.ActiveMq.ZeroMq.kafka.这几种MQ到底应该选择哪个?要根据自己项目的业务场景和需求.下面我列出这些MQ之间的对比数据和资料.第一部分 ...
- RabbitMQ、ActiveMQ和ZeroMQ
消息中间件的技术选型心得-RabbitMQ.ActiveMQ和ZeroMQ 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs RabbitMQ.Active ...
- 消息中间件的技术选型心得-RabbitMQ、ActiveMQ和ZeroMQ
消息中间件的技术选型心得-RabbitMQ.ActiveMQ和ZeroMQ 作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs RabbitMQ.Active ...
- Python之路【第九篇】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy
Python之路[第九篇]:Python操作 RabbitMQ.Redis.Memcache.SQLAlchemy Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用 ...
- (转)消息中间件的技术选型心得-RabbitMQ、ActiveMQ和ZeroMQ
RabbitMQ.ActiveMQ和ZeroMQ都是极好的消息中间件,但是我们在项目中该选择哪个更适合呢?很多开发者面临这个烦恼.下面我会对这三个消息中间件做一个比较,看了后你们就心中有数了. Rab ...
- Kafka、ActiveMQ、RabbitMQ、RocketMQ 区别以及高可用原理
为什么使用消息队列 其实就是问问你消息队列都有哪些使用场景,然后你项目里具体是什么场景,说说你在这个场景里用消息队列是什么? 面试官问你这个问题,期望的一个回答是说,你们公司有个什么业务场景,这个业务 ...
- 消息队列RabbitMq、ActiveMq、ZeroMq、kafka之间的比较
MQ框架非常之多,比较流行的有RabbitMq.ActiveMq.ZeroMq.kafka.这几种MQ到底应该选择哪个?要根据自己项目的业务场景和需求.下面我列出这些MQ之间的对比数据和资料. 第一部 ...
随机推荐
- javascript实现当前页面截屏
javascript实现当前页面截屏 一.前言 有客户要求能对用户当前页面进行指定区域截屏,类似qq截屏的实现效果.比如用户在处理工作的时候,将当前页面录入后的一些信息进行截图下载保存.但又不能安装任 ...
- Activity packagename has leaked window android.widget.PopupWindow$PopupDecorView{4f92660 V.E...... .......D 0,0-455,600} that was originally added here
原因是在销毁Activity时,Activity中的popupwindow还处于显示状态. 解决方法是重写Activity的onDestroy()方法,在Activity销毁前调用popupWindo ...
- HDU 4920 居然会超时
题意:求两个n*n的矩阵相乘的结果,得出的每个元素%3: 分析:2000ms然后n的范围是800,我们自己估算的时间复杂度并不会超时,但是结果就是超时了. #include <cstdio> ...
- IE8下ajax请求失败的解决方案
今天发现IE9以下的浏览器,ajax请求返回数据异常研究半天发现是type参数未设置,由于默认方式是Get,添加上type:“post”就恢复正常了
- Mono.Android 基础
Mono.Android 基础 (地址) Mono.Android项目结构是 — Project + Assets + Resources + drawable + layout + values R ...
- 如何使用Python3.4连接MySQL
http://www.tuicool.com/articles/yqayEv import pymysql conn = pymysql.connect(host='localhost', port= ...
- MSP430单片机的两种SPI总线实现方式
MSP430单片机上的SPI总线的实现方式分为两种:硬件实现和软件实现. 二者的抽象层次不同,硬件实现方式下程序员只需要完成总线协议的寄存器层,即一字节(char,8位二进制)数据,而软件实现方式下程 ...
- JS——全选与反选
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 关于判断checkbox选中问题
attr和prop的区别: 因为DOM节点属性可以理解为静态的,当页面渲染完,checked属性就确定了,就是checked.而HTML元素属性是动态的,随时可以改变,而且对于checked这个属性, ...
- iOS设计模式和机制之观察者模式
观察者模式定义了一种一对多的依赖关系,让多个观察者对象同时监听某一个主题对象.这个主题对象在状态上发生变化时,会通知所有观察者对象,使它们能够自动更新自己. 观察者模式的思想:当某对象改变时,观察者会 ...