zoukankan      html  css  js  c++  java
  • Redis数据结构

    一、String

    string的应用场景

    • 分布式锁
    • 布隆过滤器
    • 缓存
    • 自增、自减:统计计数
    • 分布式主键ID生成:incrby orderId 10000  一次获取批量的ID ,批量获取减少与Redis交互的频率。
    • session共享

    二、hash类型

    hash的特点:

    • hash类型下的value只能存储字符串,不允许存储其他数据类型,不存在嵌套现象,如果数据未取到,则返回 nil
    • 每个hash可以存储2^32-1个键值对
    • hash类型非常贴近对象的数据存储形式,并且可以灵活添加、删除对象属性。但hash设计初衷不是为了存储大量对象而设计的,切记不可乱用,更不可以将hash作为对象列表使用。
    • hgetall操作可以获取全部属性,如果内部field过多,遍历整体数据效率就会很低,有可能成为数据访问瓶颈。

    hash的应用场景

    1、购物车 :key=userId ,value 是各个商品对应的购买数量;

    2、用户的信息

    三、list

    list可以实现:

     

     

    队列

    阻塞队列

    BRPOPLPUSH :阻塞式等待,将列表 source 中的最后一个元素 (尾元素) 弹出,并返回给客户端。将 source 弹出的元素插入到列表 destination ,作为 destination 列表的的头元素。超时参数 timeout 接受一个以秒为单位的数字作为值。超时参数设为 0 表示阻塞时间可以无限期延长 (block indefinitely) 。 BRPOPLPUSH source destination timeout  ;这种方式可以避免数据弹出后处理业务失败 ,而数据丢失。我们可以通过LREM 删除处理成功的数据,也可以通过该指令获取处理失败的数据。

     四、set

    1、抽奖:srandmember 可以随机获取元素,但是他不会剔除已经查询过的元素,即会重复抽奖

    我们使用spop 抽奖可以移除已经获取的元素

     

     2、关注的人、按照交集可以实现共同关注的人

     

     五、zset 

    zset是set的一个升级版本,他在set的基础上增加了一个顺序属性,这一属性在添加修改元素的时候可以指定,每次指定后,zset会自动重新按新的值调整顺序。 可以对指定键的值进行排序权重的设定,它应用排名模块比较多。

    古之学者为己,今之学者为人
  • 相关阅读:
    Lambda表达式、解决端口占用问题
    springboot初始化报错: Failed to instantiate [XXX]: Specified class is an interface
    Spring声明式事务配置
    Springboot集成jsp
    点击redisserver.exe闪退
    Spring学习笔记
    Mybatis中 <![CDATA[ ]]> 的使用
    Mybatis学习笔记
    context:annotationconfig与context:componentscan的作用
    Spring学习笔记
  • 原文地址:https://www.cnblogs.com/jalja365/p/14786519.html
Copyright © 2011-2022 走看看