面试官问:你们项目中用Redis来干什么?

你好,我是田哥

面试中,被问到Redis问题的概率非常高,如果问一些理论性的问题,相信你只要背背八股文就能搞定,但,如果结合项目来问就没那么好对付了。

这里给你推荐一个在线刷java面试题的神器:

woaijava.cc/mianshi/index

本文,咱们就来聊聊Redis的使用场景(如果你项目中没有用到Redis,你看完下面的这些使用场景,你一定能编出几个来8ed99aaa8ce14c1deaf05eb0d538216b.png),我给你准备了16种Redis使用场景:

缓存数据共享分布式分布式锁全局 ID计数器限流位统计购物车用户消息时间线 timeline消息队列抽奖点赞签到打卡商品标签商品筛选用户关注推荐模型排行榜

接下来,我们逐个分析:

1、缓存

作为Key-Value形态的内存数据库,Redis 最先会被想到的应用场景便是作为数据缓存。而使用 Redis 缓存数据非常简单,只需要通过string类型将序列化后的对象存起来即可,不过也有一些需要注意的地方:

必须保证不同对象的 key 不会重复,并且使 key 尽量短,一般使用类名(表名)加主键拼接而成。

选择一个优秀的序列化方式也很重要,目的是提高序列化的效率和减少内存占用。 

2、数据共享分布式

因为 Redis 是分布式的独立服务,可以在多个应用之间共享

例如:分布式Session


     
     
  1. <dependency> 
  2.  <groupId>org.springframework.session</groupId> 
  3.  <artifactId>spring-session-data-redis</artifactId> 
  4. </dependency>

3、分布式锁

setnx方法,只有不存在时才能添加成功,返回true


     
     
  1. public static boolean getLock(String key) {
  2.     Long flag = jedis.setnx(key,  "1");
  3.      if (flag ==  1) {
  4.         jedis.expire(key,  10);
  5.     }
  6.      return flag ==  1;
  7. }
  8. public static void releaseLock(String key) {
  9.     jedis.del(key);
  10. }

4、全局ID

int类型,incrby,利用原子性

incrby userid 1000

分库分表的场景,一次性拿一段

5、计数器

int类型,incr方法

例如:文章的阅读量、微博点赞数、允许一定的延迟,先写入Redis再定时同步到数据库

6、限流

int类型,incr方法

以访问者的ip和其他信息作为key,访问一次增加一次计数,超过次数则返回false

7、位统计

bitcount(1.6.6的bitmap数据结构介绍)

字符是以8位二进制存储的


     
     
  1. set k1 a
  2. setbit k1  6  1
  3. setbit k1  7  0
  4. get k1 
  5. /* 6 7 代表的a的二进制位的修改
  6. a 对应的ASCII码是97,转换为二进制数据是01100001
  7. b 对应的ASCII码是98,转换为二进制数据是01100010
  8. 因为bit非常节省空间(1 MB=8388608 bit),可以用来做大数据量的统计。
  9. */

例如:在线用户统计,留存用户统计


     
     
  1. setbit onlineusers  01 
  2. setbit onlineusers  11 
  3. setbit onlineusers  20

支持按位与、按位或等等操作


     
     
  1. BITOPANDdestkeykey[key...] ,对一个或多个 key 求逻辑并,并将结果保存到 destkey 。       
  2. BITOPORdestkeykey[key...] ,对一个或多个 key 求逻辑或,并将结果保存到 destkey 。 
  3. BITOPXORdestkeykey[key...] ,对一个或多个 key 求逻辑异或,并将结果保存到 destkey 。 
  4. BITOPNOTdestkeykey ,对给定 key 求逻辑非,并将结果保存到 destkey 。

计算出7天都在线的用户

BITOP"AND" "7_days_both_online_users" "day_1_online_users" "day_2_online_users" ...  "day_7_online_users"

8、购物车

String 或hash。所有String可以做的hash都可以做

40221b73e76b0faaf711cee9c78d1111.png
  • key:用户id;field:商品id;value:商品数量。

  • +1:hincr。-1:hdecr。删除:hdel。全选:hgetall。商品数:hlen。

9、用户消息时间线timeline

list,双向链表,直接作为timeline就好了。插入有序

10、消息队列

List提供了两个阻塞的弹出操作:blpop/brpop,可以设置超时时间

  • blpop:blpop key1 timeout 移除并获取列表的第一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

  • brpop:brpop key1 timeout 移除并获取列表的最后一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

上面的操作。其实就是java的阻塞队列。学习的东西越多。学习成本越低

  • 队列:先进先除:rpush blpop,左头右尾,右边进入队列,左边出队列

  • 栈:先进后出:rpush brpop

11、抽奖

自带一个随机获得值

spop myset

12、点赞、签到、打卡

9c487d7b406181f6bcd7ae51d9f29146.png

假如上面的微博ID是t1001,用户ID是u3001

用 like:t1001 来维护 t1001 这条微博的所有点赞用户

  • 点赞了这条微博:sadd like:t1001 u3001

  • 取消点赞:srem like:t1001 u3001

  • 是否点赞:sismember like:t1001 u3001

  • 点赞的所有用户:smembers like:t1001

  • 点赞数:scard like:t1001

是不是比数据库简单多了。

13、商品标签

3db4f23ac7e215408067ab245fd4fe09.png

老规矩,用 tags:i5001 来维护商品所有的标签。

  • sadd tags:i5001 画面清晰细腻

  • sadd tags:i5001 真彩清晰显示屏

  • sadd tags:i5001 流程至极

14、商品筛选


     
     
  1. // 获取差集
  2. sdiff set1 set2
  3. // 获取交集(intersection )
  4. sinter set1 set2
  5. // 获取并集
  6. sunion set1 set2
9a239d5b062ad57f53b073e33394c4f1.png

假如:iPhone11 上市了


     
     
  1. sadd brand:apple iPhone11
  2. sadd brand:ios iPhone11
  3. sad screensize: 6.0 -6.24 iPhone11
  4. sad screentype:lcd iPhone  11

赛选商品,苹果的、ios的、屏幕在6.0-6.24之间的,屏幕材质是LCD屏幕

sinter brand:apple brand:ios screensize:6.0-6.24 screentype:lcd

15、用户关注、推荐模型

follow 关注 fans 粉丝

相互关注:

  • sadd 1:follow 2

  • sadd 2:fans 1

  • sadd 1:fans 2

  • sadd 2:follow 1

我关注的人也关注了他(取交集):

  • sinter 1:follow 2:fans

可能认识的人:

  • 用户1可能认识的人(差集):sdiff 2:follow 1:follow

  • 用户2可能认识的人:sdiff 1:follow 2:follow

16、排行榜

id 为6001 的新闻点击数加1:

zincrby hotNews:20190926 1 n6001

获取今天点击最多的15条:

zrevrange hotNews:20190926 0 15 withscores
402704f359440d3bf790399828f1deeb.png

最后,给你推荐一个刷java面试题的神器(已录入1000多题):

网站:www.woaijava.cc (也可以文末左下角阅读原文直接访问)

2e37be860b705cd48353d0fa5e6c7910.png

面经系列

第一次面试,面完,直接拒了!

深圳 | 1面 耗时 40多分钟

面试考代码,居然翻车了!

顺丰面试,第二个问题把我劝退了!

在线刷题,我成功入职 搜狐!

精彩文章

资料:秒杀系统设计,文档、代码和视频

用Spring Boot搞了个医院项目,附源码!

海康 面试:说说MyBatis 插件机制

50000多字,线程池源码详解!建议收藏

手把手教:如何准备面试!

dubbo源码深度分析:62个文档+中文注释+流程图+思维导图

来源:https://blog.csdn.net/o9109003234/article/details/128195932
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值