redis补充
1、Redis发布和订阅操作
1、 给某个频道发布消息:
publish channel pessage
2、订阅某个频道的消息:
subscribe channel
先订阅再发布,订阅可以订阅多个频道
2、RDB和AOF的两种数据持久化机制
1、持久化: redis 提供了两种数据备份方式,一 种是RDB,另外一种是AOF,以下将详细介绍这两种备份策略:
开启关闭:RDB:开启:默认开启。关闭:把配置文件中所有的save都注释,就是关闭了。
AOF:开启: 在配置文件中appendonly。yes即开启了aof,为no关闭。
同步机制:RDB:可以指定某个时间内发生多少个命令进行同步。比如1分钟内发生了2次命令,就做一次同步。
AOF:每秒同步或者每次发生命令后同步
存储内容:RDB:存储的是redis里面的具体的值
AOF:存储的是执行的写操作命令
存储文件的路径:RDB:根据din以及dbfilename来指定路径和具体的文件名
AOF:根据dir以人及appendflename来指定具体的路径和文件名
优点:RDB:(1)存储数据到文件中会进行压缩,文件体积比aof小。(2) 因为存储的是redis具体的值,并且会经过压缩,因此在恢复的时候速度比AOF快。
(3)非常适用于备份。
ADF:(1) AOF的策略是每秒钟或者每次发生写操作的时候都会同步,因此即使服务器故障,最多只会丢失1秒的数据。
(2) AOF存储的是Redis命令,并且是直接追加到aof文件后面,因此每次备份的时候只要添加新的數据进去就可以了。
(3) 如果AOF文件比较大了,那么Redis会进行重写,只保留最小的命令集合。
缺点:RDB:(1) RDB在多少时间内发生了多少写操作的时候就会出发同步机制,因为采用压缩机制,RDB在同步的时候都重新保存整个Redis中的数据,
因此你一般会设置在最少5分钟才保存一-次数据。在这种情况下,一旦服务器故障,会造成5分钟的数据丢失。
(2)在数据保存进RDB的时候,Redis会forK出一个子进程用来同步,在数据量比较大的时候,可能会非常耗时。
ADF:(1) AOF文件因为没有压缩,因此体积比RDB大。(2) AOF是在每秒或者每次写操作都进行备份,因此如果并发了比较大,效率可能有点慢。
(3)AOF文件因为存储的是命令,因此在灾难恢复的时候Redis会重新运行AOF中的命令,速度不及RDB。
3、Redis设置连接密码
vim redis.conf
找到requirepass(使用/requirepass查找),取消注释,在后面填写密码
设置完后重启redis
4、其它机器连接本机
vim redis.conf
找到bind,在后面添加本机的IP地址,这样别的机器就能连接成功了。
from redis import Redis
xtredis = Redis(host='172.17.59.171',port=6379)
# 1、操作字符串
# xtredis.set('username','dcp')
# xtredis.delete('username')
# 2、列表操作
# xtredis.lpush('languages','dcp')
# xtredis.lpush('languages','asd')
# xtredis.lpush('languages','dsa')
# print(xtredis.lrange('languages','0','-1'))
# 3、集合操作
# xtredis.sadd('team','li')
# xtredis.sadd('team','asd')
# xtredis.sadd('team','dsa')
# print(xtredis.smembers('team'))
# 4、哈希的操作
# xtredis.hset('website','baidu','www.baidu.com')
# xtredis.hset('website','google','www.google.com')
# print(xtredis.hgetall('website'))
# 5、事务的操作
# pip = xtredis.pipeline()
# pip.set('username','dcp')
# pip.set('password','1111')
# pip.execute()
#发布与订阅功能
# 异步发送邮件
ps = xtredis.pubsub()
ps.subscribe('email')
while True:
for item in ps.listen():
if item['type'] == 'message':
data = item['data']
print(data)
# 发送邮件