首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
澳柯玛鼠鼠
无 Java
关注
已关注
取消关注
Redis 面试题
@敲代码的帅哥:
redis面试题总结(附答案)
一、Redis是什么?Redis是一个key-value存储系统,它支持存储的value类型相对更多,包括string、list、set、zset(sorted set --有序集合)和hash。这些数据结构都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,Redis支持各种不同方式的排序。为了保证效率,数据都是缓存在内存中,Redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。二、Redis都有哪些使用场景?Redis是基于内存的nosql数据库,可以通过新建线程的形式进行持久化,不影响Redis单线程的读写操作通过list取最新的N条数据模拟类似于token这种需要设置过期时间的场景发布订阅消息系统定时器、计数器三、Redis有哪些功能?1、基于本机内存的缓存当调用api访问数据库时,假如此过程需要2秒,如果每次请求都要访问数据库,那将对服务器造成巨大的压力,如果将此sql的查询结果存到Redis中,再次请求时,直接从Redis中取得,而不是访问数据库,效率将得到巨大的提升,Redis可以定时去更新数据(比如1分钟)。2、如果电脑重启,写入内存的数据是不是就失效了呢,这时Redis还提供了持久化的功能。3、哨兵(Sentinel)和复制Sentinel可以管理多个Redis服务器,它提供了监控、提醒以及自动的故障转移功能;复制则是让Redis服务器可以配备备份的服务器;Redis也是通过这两个功能保证Redis的高可用;4、集群(Cluster)单台服务器资源总是有上限的,CPU和IO资源可以通过主从复制,进行读写分离,把一部分CPU和IO的压力转移到从服务器上,但是内存资源怎么办,主从模式只是数据的备份,并不能扩充内存;现在我们可以横向扩展,让每台服务器只负责一部分任务,然后将这些服务器构成一个整体,对外界来说,这一组服务器就像是集群一样。四、Redis支持的数据类型有哪些?字符串hashlistsetzset五、Redis取值存值问题1、先把Redis的连接池拿出来JedisPool pool = new JedisPool(new JedisPoolConfig(),"127.0.0.1"); Jedis jedis = pool.getResource();2、存取值jedis.set("key","value");jedis.get("key");jedis.del("key");//给一个key叠加valuejedis.append("key","value2");//此时key的值就是value + value2;//同时给多个key进行赋值:jedis.mset("key1","value1","key2","value2");3、对map进行操作Map<String,String> user = new HashMap();user.put("key1","value1");user.put("key2","value2");user.put("key3","value3");//存入jedis.hmset("user",user);//取出user中key1 List<String> nameMap = jedis.hmget("user","key1");//删除其中一个键值jedis.hdel("user","key2");//是否存在一个键jedis.exists("user");//取出所有的Map中的值:Iterator<String> iter = jedis.hkeys("user").iterator();while(iter.next()){ jedis.hmget("user",iter.next());}六、Redis为什么是单线程的?代码更清晰,处理逻辑更简单;不用考虑各种锁的问题,不存在加锁和释放锁的操作,没有因为可能出现死锁而导致的性能问题;不存在多线程切换而消耗CPU;无法发挥多核CPU的优势,但可以采用多开几个Redis实例来完善;七、Redis真的是单线程的吗?Redis6.0之前是单线程的,Redis6.0之后开始支持多线程;redis内部使用了基于epoll的多路服用,也可以多部署几个redis服务器解决单线程的问题;redis主要的性能瓶颈是内存和网络;内存好说,加内存条就行了,而网络才是大麻烦,所以redis6内存好说,加内存条就行了;而网络才是大麻烦,所以redis6.0引入了多线程的概念,redis6.0在网络IO处理方面引入了多线程,如网络数据的读写和协议解析等,需要注意的是,执行命令的核心模块还是单线程的。八、Redis持久化有几种方式?redis提供了两种持久化的方式,分别是RDB(Redis DataBase)和AOF(Append Only File)。RDB,简而言之,就是在不同的时间点,将redis存储的数据生成快照并存储到磁盘等介质上;AOF,则是换了一个角度来实现持久化,那就是将redis执行过的所有写指令记录下来,在下次redis重新启动时,只要把这些写指令从前到后再重复执行一遍,就可以实现数据恢复了。其实RDB和AOF两种方式也可以同时使用,在这种情况下,如果redis重启的话,则会优先采用AOF方式来进行数据恢复,这是因为AOF方式的数据恢复完整度更高。如果你没有数据持久化的需求,也完全可以关闭RDB和AOF方式,这样的话,redis将变成一个纯内存数据库,就像memcache一样。九、Redis和 memecache 有什么区别?1、Redis相比memecache,拥有更多的数据结构和支持更丰富的数据操作。(1)Redis支持key-value,常用的数据类型主要有String、Hash、List、Set、Sorted Set。(2)memecache只支持key-value。2、内存使用率对比,Redis采用hash结构来做key-value存储,由于其组合式的压缩,其内存利用率会高于memecache。3、性能对比:Redis只使用单核,memecache使用多核。4、Redis支持磁盘持久化,memecache不支持。Redis可以将一些很久没用到的value通过swap方法交换到磁盘。5、Redis支持分布式集群,memecache不支持。十、Redis支持的 java 客户端都有哪些?Redisson、Jedis、lettuce 等等,官方推荐使用 Redisson。十一、jedis 和 redisson 有哪些区别?Jedis 和 Redisson 都是Java中对Redis操作的封装。Jedis 只是简单的封装了 Redis 的API库,可以看作是Redis客户端,它的方法和Redis 的命令很类似。Redisson 不仅封装了 redis ,还封装了对更多数据结构的支持,以及锁等功能,相比于Jedis 更加大。但Jedis相比于Redisson 更原生一些,更灵活。十二、什么是缓存穿透?怎么解决?1、缓存穿透一般的缓存系统,都是按照key去缓存查询,如果不存在对用的value,就应该去后端系统查找(比如DB数据库)。一些恶意的请求会故意查询不存在的key,请求量很大,就会对后端系统造成很大的压力。这就叫做缓存穿透。2、怎么解决?对查询结果为空的情况也进行缓存,缓存时间设置短一点,或者该key对应的数据insert之后清理缓存。对一定不存在的key进行过滤。可以把所有的可能存在的key放到一个大的Bitmap中,查询时通过该Bitmap过滤。3、缓存雪崩当缓存服务器重启或者大量缓存集中在某一时间段失效,这样在失效的时候,会给后端系统带来很大的压力,导致系统崩溃。4、如何解决?在缓存失效后,通过加锁或者队列来控制读数据库写缓存的线程数量。比如对某个key只允许一个线程查询数据和写缓存,其它线程等待;做二级缓存;不同的key,设置不同的过期时间,让缓存失效的时间尽量均匀;十三、怎么保证缓存和数据库数据的一致性?1、淘汰缓存数据如果为较为复杂的数据时,进行缓存的更新操作就会变得异常复杂,因此一般推荐选择淘汰缓存,而不是更新缓存。2、选择先淘汰缓存,再更新数据库假如先更新数据库,再淘汰缓存,如果淘汰缓存失败,那么后面的请求都会得到脏数据,直至缓存过期。假如先淘汰缓存再更新数据库,如果更新数据库失败,只会产生一次缓存穿透,相比较而言,后者对业务则没有本质上的影响。3、延时双删策略如下场景:同时有一个请求A进行更新操作,另一个请求B进行查询操作。请求A进行写操作,删除缓存请求B查询发现缓存不存在请求B去数据库查询得到旧值请求B将旧值写入缓存请求A将新值写入数据库次数便出现了数据不一致问题。采用延时双删策略得以解决。public void write(String key,Object data){ redisUtils.del(key); db.update(data); Thread.Sleep(100); redisUtils.del(key);}这么做,可以将1秒内所造成的缓存脏数据,再次删除。这个时间设定可根据俄业务场景进行一个调节。4、数据库读写分离的场景两个请求,一个请求A进行更新操作,另一个请求B进行查询操作。请求A进行写操作,删除缓存请求A将数据写入数据库了,请求B查询缓存发现,缓存没有值请求B去从库查询,这时,还没有完成主从同步,因此查询到的是旧值请求B将旧值写入缓存数据库完成主从同步,从库变为新值依旧采用延时双删策略解决此问题。十四、Redis,什么是缓存穿透?怎么解决?1、缓存穿透一般的缓存系统,都是按照key去缓存查询,如果不存在对用的value,就应该去后端系统查找(比如DB数据库)。一些恶意的请求会故意查询不存在的key,请求量很大,就会对后端系统造成很大的压力。这就叫做缓存穿透。2、怎么解决?对查询结果为空的情况也进行缓存,缓存时间设置短一点,或者该key对应的数据insert之后清理缓存。对一定不存在的key进行过滤。可以把所有的可能存在的key放到一个大的Bitmap中,查询时通过该Bitmap过滤。3、缓存雪崩当缓存服务器重启或者大量缓存集中在某一时间段失效,这样在失效的时候,会给后端系统带来很大的压力,导致系统崩溃。4、如何解决?在缓存失效后,通过加锁或者队列来控制读数据库写缓存的线程数量。比如对某个key只允许一个线程查询数据和写缓存,其它线程等待;做二级缓存;不同的key,设置不同的过期时间,让缓存失效的时间尽量均匀;十五、Redis怎么实现分布式锁?使用Redis实现分布式锁redis命令:set users 10 nx ex 12 原子性命令//使用uuid,解决锁释放的问题@GetMappingpublic void testLock() throws InterruptedException { String uuid = UUID.randomUUID().toString(); Boolean b_lock = redisTemplate.opsForValue().setIfAbsent("lock", uuid, 10, TimeUnit.SECONDS); if(b_lock){ Object value = redisTemplate.opsForValue().get("num"); if(StringUtils.isEmpty(value)){ return; } int num = Integer.parseInt(value + ""); redisTemplate.opsForValue().set("num",++num); Object lockUUID = redisTemplate.opsForValue().get("lock"); if(uuid.equals(lockUUID.toString())){ redisTemplate.delete("lock"); } }else{ Thread.sleep(100); testLock(); }}备注:可以通过lua脚本,保证分布式锁的原子性。十六、Redis分布式锁有什么缺陷?Redis 分布式锁不能解决超时的问题,分布式锁有一个超时时间,程序的执行如果超出了锁的超时时间就会出现问题。Redis容易产生的几个问题:锁未被释放B锁被A锁释放了数据库事务超时锁过期了,业务还没执行完Redis主从复制的问题十七、Redis如何做内存优化?1、缩短键值的长度缩短值的长度才是关键,如果值是一个大的业务对象,可以将对象序列化成二进制数组;首先应该在业务上进行精简,去掉不必要的属性,避免存储一些没用的数据;其次是序列化的工具选择上,应该选择更高效的序列化工具来降低字节数组大小;以JAVA为例,内置的序列化方式无论从速度还是压缩比都不尽如人意,这时可以选择更高效的序列化工具,如: protostuff,kryo等2、共享对象池对象共享池指Redis内部维护[0-9999]的整数对象池。创建大量的整数类型redisObject存在内存开销,每个redisObject内部结构至少占16字节,甚至超过了整数自身空间消耗。所以Redis内存维护一个[0-9999]的整数对象池,用于节约内存。 除了整数值对象,其他类型如list,hash,set,zset内部元素也可以使用整数对象池。因此开发中在满足需求的前提下,尽量使用整数对象以节省内存。3、字符串优化4、编码优化5、控制key的数量
点赞 13
评论 2
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
08-18 22:05
天津字节跳动科技有限公司_产品研发_软件工程师(准入职员工)
字节跳动内推
给点真实入职体验 1️⃣字节福利名不虚传 食堂免费,没夸张,是真好吃,比我大学食堂强很多倍 各种零食下午茶饮料畅饮,基本半免费 入职6险一金,顶格公积金 出差的待遇也基本拉满,一线城市700/晚的酒店,也是公司让我飞上了国内2k+的机票……谢谢字节让我第一次一个人订到这个价格的机酒 2️⃣这里没有landing 没有人会手把手带 老板只负责验收成果 遇到了困难,再难只能自己想办法解决 就算是唯一的应届生,老板不会因此而降低标准 所有的问题都没有答案,也没有人会帮助,只能自己解决 8️⃣最后,我依然开心加入字节,也欢迎大家来~用我的码我给大家跟进一下字节跳动2026校园招聘启动!招聘利好:持续扩...
字节跳动公司福利 1061人发布
点赞
评论
收藏
分享
08-19 16:22
沐瞳科技_游戏策划(准入职员工)
沐瞳科技内推,沐瞳科技内推码
游戏运营问题:看你以往经历没有涉及游戏,为什么想进入这行?深挖活动运营经历:评估效果会关注哪些指标?新游戏上线后,你会优先关注哪些数据?如果游戏下载量、留存、回流同时出问题,先解决哪个?平时玩什么游戏?为什么喜欢它?(建议提前准备游戏分析)你觉得《MLBB》有哪些可以改进的地方?📚 高频考点整理▪️ 游戏运营理解:内容搭建、版本迭代、用户/渠道运营、数据分析缺一不可。▪️ 数据指标:留存率、ARPU、付费率、活跃玩家分析是核心。▪️ 新手引导设计:简洁提示+适当奖励+难度梯度是关键。▪️ 活动策划:节日活动、社区互动、召回机制都能提升在线人数。🔍 行业工具推荐数据分析常用:七麦、蝉大师、S...
点赞
评论
收藏
分享
08-13 13:45
杭州电子科技大学信息工程学院 单片机
佬们,简历改成这样还有什么建议吗
😭😭😭感觉已经差不多了吧
点赞
评论
收藏
分享
06-30 15:54
湖北文理学院 Java
这个面试官什么意思啊
他是让我运行这个项目么?,但是我没有服务号啊😅
自学java狠狠赚一...:
骗你点star的,港卵公司,记得把star收回去
点赞
评论
收藏
分享
08-21 14:16
陕西理工大学 运营
谁看了不说一句耐面王
10天面了6次
flmz_Kk:
强度好大,是无线复活吗
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
点赞
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
ES(Elasticsearch)面试常见八股整理
4.6W
2
...
字节后端三面
3.4W
3
...
腾讯后端面经
1.9W
4
...
27双非,不靠包装邪修拿下美团实习
8586
5
...
影石嵌入式一面
7548
6
...
出生滑伪all in到最后一无所有😡
5630
7
...
美团后端一面
5050
8
...
美团秋招Java一面
4163
9
...
老婆怕我跑,给我买了这么多礼物
4083
10
...
大疆后端面经
4054
创作者周榜
更多
正在热议
更多
#
七夕节你打算怎么过?
#
3735次浏览
78人参与
#
机械人还在等华为开奖吗?
#
236359次浏览
1183人参与
#
实习教会我的事
#
1872次浏览
15人参与
#
掌阅科技工作体验
#
8368次浏览
36人参与
#
暑假倒计时,你都干了些啥?
#
1484次浏览
15人参与
#
拼多多工作体验
#
32405次浏览
222人参与
#
哪些公司真双非友好?
#
19695次浏览
95人参与
#
机械/制造每日一题
#
60818次浏览
953人参与
#
现在还是0offer,延毕还是备考
#
1098090次浏览
7609人参与
#
远景求职进展汇总
#
57238次浏览
310人参与
#
互联网行业现在还值得去吗
#
25971次浏览
152人参与
#
秋招拿一个offer可以躺平吗
#
153800次浏览
1040人参与
#
25届如何提前做秋招准备?
#
180357次浏览
2502人参与
#
当下环境,你会继续卷互联网,还是看其他行业机会
#
126694次浏览
850人参与
#
神州信息工作体验
#
20406次浏览
126人参与
#
你喜欢工作还是上学
#
62994次浏览
733人参与
#
芯原求职进展汇总
#
16846次浏览
73人参与
#
招聘要求与实际实习内容不符怎么办
#
120733次浏览
802人参与
#
你觉得专业和学校哪个对薪资影响最大
#
69842次浏览
523人参与
#
如何看待offer收割机的行为
#
840592次浏览
6135人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务