zoukankan      html  css  js  c++  java
  • Redis(二) 扩展

    事务
    multi ... exec  之间的操作先进入等待队列,到exec时一起执行
                    事物的所有操作结果都是一起返回的,所以前一条指令的结果无法作为后一条指令的参数
                    其中的指令有语法错误时,都不执行;有“类型不匹配”等逻辑错误时,只执行对的指令;没有回滚
                    
    watch 监控一个或多个key 一旦监控的键值有修改,其后的事务就不执行
            监控范围:从开始监控到事务执行之前(实际上是从watch到exec,
                    但是由于multi...exec之间的指令是在exec这个点一起执行的,所以看上去是从watch到multi)

                    
                    
    生存时间
    expire key seconds 设置key的生存时间为seconds秒(该键在seconds秒后自动删除)
    ttl key 查看键key的剩余生存时间
    persist key 该键持久化
    ##在生存时间相关的指令前加p(pexpire pttl),时间单位变为毫秒
    expireat key unixtime 设置该键在unixtime时自动删除

    可以设置在内存到达规定时,键的自动删除策略
        {如:对所有键执行LRU;对设置了生存时间的键执行LRU;在内存满了时报错;对所有键随机删除;对设置了生存时间的键随机删除}



    排序
    sort s/l/z 返回从小到大的序列(有序集合是对元素自身的值进行排列)(若元素是纯字符串,报错)
    sort s/l/z ALPHA 按字典序输出纯字符串
    加 DESC 参数  倒序输出
    加 limit 1 2 参数 带偏移量 输出数量
    加 by (by 后可接 String、hashmap)
        形如:sort s/l/z by item:*->time   *是将sort序列循环一遍代替* ->是按hashmap中time排序
                sort s/l/z by item:*   字符串
        注:当要排序值相等时 按元素自身值排序 不存在该排序值默认为0

    by后面可加get(可加多个)#代表循环值
        形如:sort tag:ruby:posts by post:*->time DESC
                get post:*->time get #
        
    get后可加store   将结果保存在列表中,并返回列表长度
        形如:sort tag:ruby:posts by post:*->time DESC
                get post:*->time get # store sort:result
    sort很容易成为性能瓶颈 O(n+mlogm)n为要排序的数据总量 m为要返回的个数



    消息通知
    brpop lkeyA [lkeyB ...] time (time为等待时长,0为无限等待 )
        当多个等待队列都没有值时,等待,若等了time还没值,就返回nil
        当都有值时,前面的队列 优先取
        返回值是个数组  [0]为返回队列的名称 [1]返回的内容

    订阅、发布模式
    发布消息:public channel message 返回值为收到消息者的数量
    订阅频道:subscribe channel (可以订阅多个频道,进入订阅模式后,只能使用订阅相关指令)
    订阅模式三种返回值:
            “subscribe” “频道名称” “你共订阅了几个频道”
            “message”  “频道名称”   “消息内容”
            “unsubscribe”  “频道名称”  “你剩余几个频道”
    unsubscribe [channel ...] 若未指定 频道名 会取消订阅所有频道

    还可以订阅一类频道 如:psubscribe item:*

  • 相关阅读:
    workerman需要的php模块posix、pcntl、sysvshm、sysvmsg缺少,怎么办
    Linux操作:
    推荐!手把手教你使用Git
    Ninject简介(转)
    新年奉献MVC+EF(CODEFIRST)+EASYUI医药MIS系统(转)
    微软开源代码
    .NET分布式事务处理(转)
    IIS负载均衡(转)
    借助LVS+Keepalived实现负载均衡(转)
    WCF和ASP.NET Web API在应用上的选择(转)
  • 原文地址:https://www.cnblogs.com/ironPhoenix/p/4502874.html
Copyright © 2011-2022 走看看