Collin Nam


                   
   

redis常用数据类型的介绍、使用场景及使用方法

Collin 2019-08-21 8721浏览 0条评论
首页/ 正文
分享到: / / / /

一、String字符串类型
1、简介

    string 类型是 Redis 中最基本的数据类型,最常用的数据类型,甚至被很多玩家当成 redis 唯一的数据类型去使用。
string 类型在 redis 中是二进制安全(binary safe)的,这意味着 string 值关心二进制的字符串,不关心具体格式,
 你可以用它存储 json 格式或 JPEG 图片格式的字符串。
    
    字符串类型实际上可以是字符串(简单的字符串、复杂的字符串(xml、json)、数字(整数、浮点数)、二进制(图片、音频、视频)),  但最大不能超过512M。

2、使用场景

缓存功能:字符串最经典的使用场景,redis最为缓存层,Mysql作为储存层,绝大部分请求数据都是
         redis中获取,由于redis具有支撑高并发特性,所以缓存通常能起到加速读写和降低 后端压力的作用。
计数器:许多运用都会使用redis作为计数的基础工具,他可以实现快速计数、查询缓存的功能,
          同时数据可以一步落地到其他的数据源。如:视频播放数系统就是使用redis作为视频播放数计数的基础组件。
共享session:出于负载均衡的考虑,分布式服务会将用户信息的访问均衡到不同服务器上,
          用户刷新一次访问可能会需要重新登录,为避免这个问题可以用redis将用户session集中管理,
          在这种模式下只要保证redis的高可用和扩展性的,每次获取用户更新或查询登录信息都直接从redis中集中获取。
限速:处于安全考虑,每次进行登录时让用户输入手机验证码,为了短信接口不被频繁访问,
          会限制用户每分钟获取验证码的频率。
 

二、List列表类型
1、简介

       列表类型是用来储存多个有序的字符串,列表中的每个字符串成为元素(element),一个列表最多可以储存
    2的32次方-1个元素,在redis中,可以队列表两端插入(pubsh)和弹出(pop),还可以获取指定范围的元素
    列表、获取指定索引下表的元素等,列表是一种比较灵活的数据结构,它可以充当栈和队列的角色,
    优点:
            1.列表的元素是有序的,这就意味着可以通过索引下标获取某个或某个范围内的元素列表。
            2.列表内的元素是可以重复的。    

2、使用场景

     消息队列: redis的lpush+brpop命令组合即可实现阻塞队列,生产者客户端是用lupsh从列表左侧插入元素,
             多个消费者客户端使用brpop命令阻塞时的“抢”列表尾部的元素,多个客户端保证了消费的负载均衡
              和高可用性    
           
    文章列表:每个用户都有属于自己的文章列表,现在需要分页展示文章列表,此时可以考虑使用列表,列表不但有序
               同时支持按照索引范围获取元素。

    使用列表技巧: 
             lpush+lpop=Stack(栈) 
             lpush+rpop=Queue(队列) 
             lpush+ltrim=Capped Collection(有限集合) 
             lpush+brpop=Message Queue(消息队列)   

 

三、Hash哈希类型
1、简介

         hash 类型很像一个关系型数据库的数据表,hash 的 Key 是一个唯一值,Value 部分是一个 hashmap 的结构。
  是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。

        哈希结构相对于字符串序列化缓存信息更加直观,并且在更新操作上更加便捷、灵活。使用 string 类型存储,必然需要转换和解析 json 格式的字符串,即便不需要转换,在内存开销方面,还是 hash 占优势。 

        哈希类型和关系型数据库有所不同,哈希类型是稀疏的, 而关系型数据库是完全结构化的,关系型数据库可以做复杂的关系查询,而redis去模拟关系型复杂查询 开发困难,维护成本高。

2、使用场景

         存储部分变更数据,如用户信息等。

 

四、Set集合类型
1、简介

      Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
 Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

     集合类型也是用来保存多个字符串的元素,但和列表不同的是集合中不允许有重复的元素,并且集合中的元素是
 无序的,不能通过索引下标获取元素,redis除了支持集合内的增删改查,

 set 类型提供了多个 set 之间的聚合运算,如求交集、并集、补集,这些操作在 redis 内部完成,效率很高。

2、使用场景

     set 类型的特点是——不重复且无序的一组数据,并且具有丰富的计算功能,在一些特定的场景中可以高效的解决一般关系型数据库不方便做的工作。
    1. 共同好友列表:社交类应用中,获取两个人或多个人的共同好友,两个人或多个人共同关注的微博这样类似的功能,用 MySQL 的话操作很复杂,可以把每个人的好友 id 存到集合中,获取共同好友的操作就可以简单到一个取交集的命令就搞定。
    
    2、标签(tag):集合类型比较典型的使用场景,取不同兴趣圈子的交集,如一个用户对娱乐、体育比较感兴趣,另一个可能对新闻感兴 趣,这些兴趣就是标签,有了这些数据就可以得到同一标签的人,以及用户的共同爱好的标签,这些数据对于用户体验以及曾强用户粘度比较重要。(用户和标签的关系维护应该放在一个事物内执行,防止部分命令失败造成数据不一致)
    sadd=tagging(标签)
    spop/srandmember=random item(生成随机数,比如抽奖)
    sadd+sinter=social Graph(社交需求)

 

五、 sorted set有序集合类型
1、简介

      Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。有序集合的成员是唯一的,但分数(score)却可以重复。集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

2、使用场景

    比好友的“亲密度”排序显示好友列表。
     
   排行榜:有序集合经典使用场景。例如视频网站需要对用户上传的视频做排行榜,榜单维护可能是多方面:
           按照时间、按照播放量、按照获得的赞数等。
 

以上就是redis的数据类型介绍及简答的使用,最后来一个数据库事务正确执行的四个基本要素数据库事务

         一、原子性(Atomicity)

                   整个程序中的所有操作,要么全部完成,要么全部不完成,不可能停滞在中间某个环节。
        
        二、一致性(Consistency)
                    一个事务可以封装状态改变(除非它是一个只读的)。事务必须始终保持系统处于一致的状态,不管在任何给定的时间并发事务有多少。
        
        三、隔离性(Isolation)
                    隔离状态执行事务,使它们好像是系统在给定时间内执行的唯一操作。
        
        四、持久性(Durability)
                   在事务完成以后,该事务对数据库所作的更改便持久的保存在数据库之中,并不会被回滚。
 

最后修改:2019-08-21 09:59:02 © 著作权归作者所有
如果觉得我的文章对你有用,请随意赞赏
扫一扫支付

上一篇

发表评论

说点什么吧~

评论列表

还没有人评论哦~赶快抢占沙发吧~