目录

String

阅读量统计

缓存

分布式锁

解决分布式问题

Hash

操作购物车

List

微博和公众号的消息流

Set

抽奖

微信微博关注模型

Zset

排行榜


注意:本文参考  在微博微信场景下学习Redis数据结构 - 知乎

String

字符串常用操作

SET  key  value             //存入字符串键值对
MSET  key  value [key value ...]     //批量存储字符串键值对
SETNX  key  value                 //存入一个不存在的字符串键值对
GET  key                     //获取一个字符串键值
MGET  key  [key ...]         //批量获取字符串键值
DEL  key  [key ...]         //删除一个键
EXPIRE  key  seconds         //设置一个键的过期时间(秒)

原子加减

INCR  key             //将key中储存的数字值加1
DECR  key             //将key中储存的数字值减1
INCRBY  key  increment     //将key所储存的值加上increment
DECRBY  key  decrement     //将key所储存的值减去decrement

阅读量统计

这个是微信公众号的文章阅读量数量的统计,可以通过redis的string数据结构来解决。使用incr原子操作命令,redis的key是article:readcount:{文章id},当该文章被阅读时,调用incr命令,阅读数量加一,通过get该redis的key,实现文章阅读数量统计的功能。

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

缓存

可以缓存一个值,或者缓存一个对象

Set Key Value

Get Key

1.Set user:1 value (json格式数据)

2.MSet user:1:name guajia use:1:balance 1888

MGet user1:name user:1:balance

分布式锁

1 下单减库存

解决分布式问题

1 incr命令,统计阅读量(单线程,自动加锁)

2 tomcat的session存到redis中

3 分布式系统全局序列号

INCRBY orderId 1000 // redis 批量生成序列号提升性能

如项目使用 分库分表 ,就可以使用这个 ,目的是让主键ID 在都是唯一的 ,这个在实际场景非常重要。

使用INCRBY orderId 1000 (这个命令是一次生成1000个订单id 供下次生成订单使用)3

Hash

Hash常用操作

HSET  key  field  value             //存储一个哈希表key的键值
HSETNX  key  field  value         //存储一个不存在的哈希表key的键值
HMSET  key  field  value [field value ...]     //在一个哈希表key中存储多个键值对
HGET  key  field                 //获取哈希表key对应的field键值
HMGET  key  field  [field ...]         //批量获取哈希表key中多个field键值
HDEL  key  field  [field ...]         //删除哈希表key中的field键值
HLEN  key                //返回哈希表key中field的数量
HGETALL  key                //返回哈希表key中所有的键值
HINCRBY  key  field  increment         //为哈希表key中field键的值加上增量increment

Hash优缺点

优点:同类数据归类整合存储,方便数据管理,相比string操作消耗内存与cpu更小

缺点:过期功能上不能使用在field上,只能使用在key上

操作购物车

这个是京东购物车的截图,可以看到很多功能都用redis的命令可来实现。在redis中保存对商品id、购物车id等等id的操作,在前端保存对于该商品的描述,在操作购物车的时候,底层其实就是操作redis的命令。

添加商品:hset cart:1001 1088 1
添加数量:hincrby cart:1001 1088 1
商品总数:hlen cart:1001
删除商品:hdel cart:1001 1008
获取购物车所有商品: hgetall cart:1001

List

List常用操作

LPUSH  key  value [value ...]         //将一个或多个值value插入到key列表的表头(最左边)
RPUSH  key  value [value ...]         //将一个或多个值value插入到key列表的表尾(最右边)
LPOP  key            //移除并返回key列表的头元素
RPOP  key            //移除并返回key列表的尾元素
LRANGE  key  start  stop        //返回列表key中指定区间内的元素,区间以偏移量start和stop指定BLPOP  key  [key ...]  timeout    //从key列表表头弹出一个元素,若列表中没有元素,阻塞等待,timeout秒,如果timeout=0,一直阻塞等待
BRPOP  key  [key ...]  timeout     //从key列表表尾弹出一个元素,若列表中没有元素,阻塞等待,timeout秒,如果timeout=0,一直阻塞等待

微博和公众号的消息流

这是我们经常使用的新浪微博,我们看在微博文章中如何使用redis的list数据结构。新浪微博是使用redis的大户,据在新浪工作的朋友说,新浪使用redis的总容量超过500T,可想而知几乎70%的功能都在redis中操作。

如微博你关注了1000个大V 每个大V 一天放两条数据 ,有1亿用户 。那么数据量有多大。可能有几百M的数据。 如果使用数据库 查询效率那就不是很高了

比如 你关注了小明和小红。

小明发了一条消息: 使用 LPUSH msg:小明Id 消息Id

小红发了一条消息: 使用 LPUSH msg:小红Id 消息Id

查看最新的微博消息: 使用LRANGE msg:小红Id 0 4 这个就是从左侧取下标是0到4的消息 意味着是取小红发的最新的5条消息的消息ID 进而从缓存里面取出对应的消息内容

Set

Set常用操作

SADD  key  member  [member ...]            //往集合key中存入元素,元素存在则忽略,若key不存在则新建
SREM  key  member  [member ...]            //从集合key中删除元素
SMEMBERS  key                    //获取集合key中所有元素
SCARD  key                    //获取集合key的元素个数
SISMEMBER  key  member            //判断member元素是否存在于集合key中
SRANDMEMBER  key  [count]            //从集合key中选出count个元素,元素不从key中删除
SPOP  key  [count]                //从集合key中选出count个元素,元素从key中删除

Set运算操作

SINTER  key  [key ...]                 //交集运算
SINTERSTORE  destination  key  [key ..]        //将交集结果存入新集合destination中
SUNION  key  [key ..]                 //并集运算
SUNIONSTORE  destination  key  [key ...]        //将并集结果存入新集合destination中
SDIFF  key  [key ...]                 //差集运算
SDIFFSTORE  destination  key  [key ...]        //将差集结果存入新集合destination中

抽奖

使用这个抽奖界面作为set的使用场景的例子,相信大家对这个界面都很熟悉,微信小程序的“抽奖”功能,这个是使用redis的set数据结构的典型场景。当用户点击“参与抽奖”,也就是把将用户ID加入集合中:

SADD key {userID}

查看参与抽奖的所有用户:

SMEMBERS key

抽取count名中奖用户

SRANDMEMBER key [count]

微信微博关注模型

SDIFF set1 set2 set3 是以 set1为基准 与set2和set3的并集 的差集

[得到a是set2和set3的并集中所没有的】

关注模型:

1.你关注的人

set guanzhu:我的id {张三、李四、王五、小明、程咬金}

2.小明关注的人

set guanzhu:小明的id {张三、赵六、尼古拉斯}

3.程咬金关注的人

set guanzhu:程咬金的id {小明、李四}

4.我和小明的共同关注:

SINTER guanzhu:我的id guanzhu:小明的id

得到就是 张三

5.我关注的人也在关注他 【我关注的某人 否也请关注小明】

SISMEMBER guanzhu:程咬金的id 小明的ID

SISMEMBER guanzhu:张三的id 小明的ID

SISMEMBER //判断 member 元素是否是集合 key 的成员

6.我可能认识的人

SDIFF guanzhu:小明的id 我的ID

Zset

ZSet常用操作

ZADD key score member [[score member]…]    //往有序集合key中加入带分值元素
ZREM key member [member …]        //从有序集合key中删除元素
ZSCORE key member             //返回有序集合key中元素member的分值
ZINCRBY key increment member        //为有序集合key中元素member的分值加上increment
ZCARD key                //返回有序集合key中元素个数
ZRANGE key start stop [WITHSCORES]    //正序获取有序集合key从start下标到stop下标的元素
ZREVRANGE key start stop [WITHSCORES]    //倒序获取有序集合key从start下标到stop下标的元素

排行榜

微博热搜榜处处使用到了Redis的有序集合这个数据结构,我们都知道有序集合是对集合的一个扩展,增加了score字段。通过score字段,我们可以选出最大或者最小的topN,这样就有了排行榜,如果用传统的数据库去实现这个功能,估计对数据性能的消耗非常大。

1)点击新闻
ZINCRBY  hotNews:20190819  1  乌镇十二时辰
2)展示当日排行前十
ZREVRANGE  hotNews:20190819  0  10  WITHSCORES
3)七日搜索榜单计算
ZUNIONSTORE  hotNews:20190813-20190819  7
hotNews:20190813  hotNews:20190814... hotNews:20190819
4)展示七日排行前十
ZREVRANGE hotNews:20190813-20190819  0  10  WITHSCORES

Redis 微博微信场景使用案例相关推荐

  1. redis 获取所有的key_在微博微信场景下学习Redis数据结构

    Redis安装 下载地址:http://redis.io/download安装步骤:1.yum install gcc2.wget http://download.redis.io/releases/ ...

  2. 分享17个微信创新应用案例 应用场景的不同应用

    17个微信创新应用案例,其实就是针对不同的应用场景结合传统行业打造的一个新的营销方式. 1.百果园--搜索附近的人品牌曝光之鼻祖 使用微信查找附近的人的时候经常排在第一位的是谁知?道吗?就是百果园,微 ...

  3. redis使用场景及案例

    最近在写一个篮球社区项目,其中redis的使用场景还挺多的,于是结合项目总结一下redis的使用场景 一.缓存 项目场景:用户登录或注册时的验证码存储,用户名 set Code:1:code 1232 ...

  4. 华为云PB级数据库GaussDB(for Redis)揭秘第五期:高斯 Redis 在IM场景中的应用

    摘要:揭秘高斯 Redis 在IM场景中的应用. 本文分享自华为云社区<华为云PB级数据库GaussDB(for Redis)揭秘第五期:高斯 Redis 在IM场景中的应用>,原文作者: ...

  5. Redis项目应用场景与实例(三):队列(List)

    文章目录 一.背景 二.项目需求 三.环境配置 四.项目代码 4.1 Redis工具类增加队列操作方法 4.2 图片上传服务增加Redis队列 五.测试与验证 六.源码 一.背景 在前两篇文章 < ...

  6. Redis典型应用场景

    一.String 1.1 字符串常用操作 SET key value //存入字符串键值对 MSET key value [key value ...] //批量存储字符串键值对 SETNX key ...

  7. python使用redis在实际场景使用_用python操作redis及redis的一些应用场景

    redis安装 网上很多windows.Linux的安装教程,可根据自己的需要寻找对应教程安装 redis-py安装 pip install redis redis可视化工具 API的使用 redis ...

  8. Redis的应用场景汇总

    Redis应用场景 Redis作为一个非关系型数据库,除了在访问速度上拥有显著优势外,其本身支持的多种数据类型也非常有用,能覆盖系统开发中的很多应用场景.下面列举的场景有的是从网上其他人的博客里看到的 ...

  9. Redis源码-String:Redis String命令、Redis String存储原理、Redis String三种编码类型、Redis字符串SDS源码解析、Redis String应用场景

    Redis源码-String:Redis String命令.Redis String存储原理.Redis String三种编码类型.Redis字符串SDS源码解析.Redis String应用场景 R ...

  10. 百万年薪背后 是人工智能领域泛起的人才泡沫 2017年07月04日 06:30 PingWest 微博 微信 空间 分享 添加喜爱 //d1.sina.com.cn/201706/26/14587

    百万年薪背后 是人工智能领域泛起的人才泡沫 2017年07月04日 06:30 PingWest 微博微信空间分享添加喜爱 (原标题:百万年薪背后 是人工智能领域不断泛起的人才泡沫) 应采访者要求,戴 ...

最新文章

  1. oracle查询之null值转化
  2. Mini汽车的保养周期
  3. python xposed_Xposed及类Xposed框架收集
  4. asp.net mvc 自定义全局过滤器 验证用户是否登录
  5. python编程选股_用Python选一个自己的股票池2
  6. ASP.NET的App_Code中放置不同语言编写的类
  7. XMPP基本概念--节(stanza)
  8. mysql union 不同字段_mysql中union和union all的区别和注意点
  9. JVM常量池和八种基本数据及字符串
  10. es 1.7 ik 配置
  11. python单循环_「单循环赛」单循环赛制 - seo实验室
  12. k1075停运吗_全国铁路大调图,怀化火车站6对旅客列车停运!
  13. Linux字符终端用鼠标移动一个红色矩形
  14. python求最大素数_python-最大素数
  15. 恒流源差分放大电路静态分析_差分放大电路分析
  16. 【ROS实践入门(九)ROS编译ORB-SLAM2运行】
  17. 51Talk-Level 7 Unit 1 L3
  18. 在手机与计算机之间进行文件传输的方式,电脑与手机快速传输文件的方法
  19. 酒店无线WiFi实名认证方案
  20. uniapp 快速实现简单首页布局

热门文章

  1. jq html怎么优化seo,长沙网站seo:浅谈SEO优化技巧之HTML结构调整!
  2. DataCastle租金预测数据竞赛个人总结
  3. wi-fidns服务器未响应,192.168.31.1登录界面
  4. 2G、 3G、 4G、5G的区别
  5. QQ消息群发助手(超级简单)
  6. 国美易卡借助云平台,国美易卡提升了用户体验
  7. 第一篇:阿里数据中台之数据中台顶层设计
  8. echarts 中国地图+穿透
  9. 虚拟机的服务器管理器怎么打开,虚拟机启动任务管理器
  10. 两种有效提高win10电脑开机速度的方法