zoukankan      html  css  js  c++  java
  • 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)
    # 发送邮件

  • 相关阅读:
    MySQL 存储过程和函数02
    MySQL 视图 存储过程(未完)
    MySQL 简单索引
    Nginx 设置前后端跨域
    Pipeline流水线 自动脚本
    luogu 2024 食物链
    spoj Corporative Network
    luogu2787 语文1(chin1)- 理理思维
    HDU6579 Operation
    luogu3857 彩灯
  • 原文地址:https://www.cnblogs.com/dcpb/p/13749653.html
Copyright © 2011-2022 走看看