redis的五种数据类型和使用场景

string类型

string类型多用于缓存

set  key  value(value可以为json字符串)

setnx多用于分布式锁(后面详细整理)

计数器

incr article:{文章id}:readcount
get article:{文章id}:readcount

web集群session共享

redis实现session共享

https://www.cnblogs.com/cxx8181602/p/9759645.html

分布式系统全局序列号(分库分表的主键可以使用此方法 批量生成id会提升性能)

incrby orderid 1000

setbit的位运算

https://www.jianshu.com/p/3a30f58ba62c

hash类型

对象存储

mset user {user_id}:name test {user_id}:age 12
hget user {user_id}:name {user_id}:age

因为redis是单线程操作,有一个非常大的忌讳就是不要让key太大,会导致执行该命令时间非常长,会阻塞线程,所以hash不要当作数据库来用,只是存储一些热数据就行

在实际应用中,可以给hash的key来分段,有一点类似于数据库分表那种思路,把数据存储在不同的key中,切记,千万不要让一个key过大

可以用来实现购物车功能

实现方式如下图

  • 以用户id为key
  • 以商品id为field
  • 商品数量为value

    购物车操作流程
  • 添加商品 hset cart:123 10010 1(123为user_id 10010为商品id)
  • 增加数量 hincrby cart:123 10010 1
  • 商品总数 hlen cart:123
  • 删除商品 hdel cart:123 10010
  • 获取购物车所有商品 hgetall cart:123

和string相比的优缺点

优点

  • 同类数据归档,存储比较方便
  • 比string消耗的cpu更小
  • 比string更节省存储空间

缺点

  • 过期功能不能用在field上,只能用在key上
  • 不适合在集群架构下大规模使用(集群数据都是分片处理的,目的是让数据分段均匀的存储,比如把user表的信息都存在hash中,就会导致那个key非常大,这样就会导致某一个redis机器上的数据非常大,导致了数据倾斜)

list类型

可以实现常见的栈和队列的数据结构,如下图

阻塞队列

Blocking MQ(阻塞队列) = LPUSH + BRPOP( BRPOP会一直等待)

微信,微博消息流

博主发消息直接发到粉丝的信息list中,粉丝直接读取即可,但是这种只适合粉丝比较少的情况

set类型应用场景

微信抽奖活动

  • 点击参与抽奖 sadd key {user_id}
  • 查看所有抽奖用户 smambers key
  • 抽取count名中奖者 srandmember key count 或者 spop key count(spop从集合中取出数据后会删除掉 适合不能重复抽奖的场景)

    ** 微信微博点赞的实现**

  • msg_id为朋友圈id user_id为点赞操作的用户的id
  • 点赞: sadd like:{msg_id} {user_id}
  • 取消点赞: srem like:{msg_id} {user_id}
  • 检查用户是否点过赞 : sismember like:{msg_id} {user_id}
  • 获取点赞用户列表: smembers like:{msg_id}
  • 获取点赞用户数: scard like:{msg_id}

可以做一些简单的推荐

用交集 差集等功能,做一些比较简单的推荐

  • sinter
  • sunion
  • sdiff

注意 交集 差集运算速度比较慢,如果使用的话 最好用单独的实例

zset

实现新闻排行榜

  • 点击新闻 zincrby news:date 1 news_id
  • 展示当日排行前10 zrevrange news:date 0 9 withscores
  • 展示7天排行榜
  • datalist为7天的日期 逐个枚举
  • zunionstore news:datelist 7 news:date1 news:date2 。。。。news:date7
  • 展示7日排行前10
  • ZRANGE news:datelist 0 9 WITHSCORES

关注我的技术公众号,每周都有优质技术文章推送。

微信扫一扫下方二维码即可关注:

redis五种数据类型的应用的更多相关文章

  1. redis五种数据类型的使用(zz)

    redis五种数据类型的使用 redis五种数据类型的使用 (摘自:http://tech.it168.com/a2011/0818/1234/000001234478_all.shtml ) 1.S ...

  2. redis五种数据类型的使用

    redis五种数据类型的使用 redis五种数据类型的使用 (摘自:http://tech.it168.com/a2011/0818/1234/000001234478_all.shtml ) 1.S ...

  3. redis五种数据类型的使用场景

    string 1.String 常用命令: 除了get.set.incr.decr mget等操作外,Redis还提供了下面一些操作: 获取字符串长度 往字符串append内容 设置和获取字符串的某一 ...

  4. Redis五种数据类型-设置key的过期时间

    1.redis命令客户端 [root@localhost bin]# ./redis-cli 127.0.0.1:6379> #是否运行着 127.0.0.1:6379> ping PON ...

  5. (转) 淘淘商城系列——Redis五种数据类型介绍

    http://blog.csdn.net/yerenyuan_pku/article/details/72855562 Redis支持五种数据类型:string(字符串),hash(哈希),list( ...

  6. Redis五种数据类型应用场景

    目录 1.1 回顾 2.1 应用场景 2.1.1 String 2.1.2 Hash 2.1.3 List 2.1.4 Zet 2.1.5 zset 3.1 小结 1.1 回顾 Redis的五种数据类 ...

  7. redis 五种数据类型

    前言 前面学会了单机, 学会了集群, 但是redis咋用啊? 或者说, redis支持哪些数据类型呢? 常用的有五种: String , Hash, List, Set, zset(SortedSet ...

  8. 《闲扯Redis三》Redis五种数据类型之List型

    一.前言 Redis 提供了5种数据类型:String(字符串).Hash(哈希).List(列表).Set(集合).Zset(有序集合),理解每种数据类型的特点对于redis的开发和运维非常重要. ...

  9. 《闲扯Redis六》Redis五种数据类型之Hash型

    一.前言 Redis 提供了5种数据类型:String(字符串).Hash(哈希).List(列表).Set(集合).Zset(有序集合),理解每种数据类型的特点对于redis的开发和运维非常重要. ...

随机推荐

  1. 手机用itunes安装更新系统

    1.[Shift+更新]:仅对固件进行更新,保留现有资料和已经安装的程序.但是已经越狱的iPhone或iPad禁止使用此方法!否则有后遗症!没有越狱的iPhone或iPad则可以直接使用此方式.2.[ ...

  2. (21)tar打包命令详解

    Linux 系统中,最常用的归档(打包)命令就是 tar,该命令可以将许多文件一起保存到一个单独的磁盘中进行归档.不仅如此,该命令还可以从归档文件中还原所需文件,也就是打包的反过程,称为解打包.1.t ...

  3. php小程序-文章发布系统(mvc框架)

    php小程序-文章发布系统(mvc框架) 一 项目视图 二 项目经验 通过对mvc微型框架的实现,对mvc理论加深,有利于以后框架的学习 三 项目源码 http://files.cnblogs.com ...

  4. 在 .NET Core Logging中使用 Trace和TraceSource

    本文介绍了在.NET Core中如何在组件设计中使用Trace和TraceSource. 在以下方面会提供一些帮助: 1.你已经为.NET Framework和.NET Core / .NET Sta ...

  5. Java ArrayList源码分析(含扩容机制等重点问题分析)

    写在最前面 这个项目是从20年末就立好的 flag,经过几年的学习,回过头再去看很多知识点又有新的理解.所以趁着找实习的准备,结合以前的学习储备,创建一个主要针对应届生和初学者的 Java 开源知识项 ...

  6. 牛客15334 Easygoing Single Tune Circulation(后缀自动机+字典树)

    传送门:Easygoing Single Tune Circulation 题意 给定n个字符串 s[i],再给出m个查询的字符串 t[i],问 t[i] 是否为某个 s[i] 循环无限次的子串. 题 ...

  7. Codeforces301D. Yaroslav and Divisors

    题意:2e5的全排列 每次询问一个区间有多少对数 满足一个数是另一个数的倍数 题解:考虑离线来做 看到有个说法说 在处理有两种约束的问题时 一般用数据结构边插入边询问的方式 这个题正是如此 我们用su ...

  8. HDU6504 Problem E. Split The Tree【dsu on tree】

    Problem E. Split The Tree Problem Description You are given a tree with n vertices, numbered from 1 ...

  9. 【uva 1151】Buy or Build(图论--最小生成树+二进制枚举状态)

    题意:平面上有N个点(1≤N≤1000),若要新建边,费用是2点的欧几里德距离的平方.另外还有Q个套餐,每个套餐里的点互相联通,总费用为Ci.问让所有N个点连通的最小费用.(2组数据的输出之间要求有换 ...

  10. hdu 5316 Magician 线段树维护最大值

    题目链接:Magician 题意: 给你一个长度为n的序列v,你需要对这个序列进行m次操作,操作一共有两种,输入格式为 type a b 1.如果type==0,你就需要输出[a,b]区间内的美丽序列 ...