首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
翠绿且神娘
华南理工大学 C++
发布于广东
关注
已关注
取消关注
@敲代码的帅哥:
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
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
07-29 15:57
OPPO_软件开发部_IT开发工程师(准入职员工)
OPPO内推
关于工作环境:base深圳前海 内部配置绝了。一整栋50层都是oppo哒,我的工位可以看到欢乐港湾和大海,零食柜自给,很感动的是每层都提供独立的隔音室,3层饭堂里,23楼是最好吃的 周边很繁华。楼下三层是大商场,午饭后我一般会和其他实习生姐妹去citywalk,好多奶茶店,茶救,奈雪 喜茶,瑞幸,奶白,煲珠公每天换着喝,好幸福 关于工作氛围 感受到相当年轻,相当扁平的氛围,我们组(销售运营部)有三个哥哥姐姐直接对接我,她们人真的很nice,笨笨的我不会时,问她们都会耐心解答~~ 于工作内容 感觉出入还是有的,问了哥哥姐姐,他们收到五六十份简历,面了6个,最后选了我,好感动好幸运。偏大客户运营方...
OPPO公司福利 679人发布
点赞
评论
收藏
分享
07-30 12:14
辽宁工业大学 C++
浪潮秒挂
测评发的快,挂的也快有没有佬知道现在浪潮招人的bg要求是什么呀
投递浪潮等公司10个岗位
点赞
评论
收藏
分享
07-04 17:40
惠州学院 Java
26双非二本简历
又来麻烦牛客的各位佬了,帮我看看我的简历吧,给点建议,这次实习简历不再是包装的了,想跳槽了,小外包公司太闲了学不到东西怕浪费时间,现在秋招提前批还是沉淀秋招哇😭😭😭
投递牛客等公司10个岗位
点赞
评论
收藏
分享
不愿透露姓名的神秘牛友
06-21 11:29
鱼皮翻车了?牛油们怎么看
凉风落木楚山秋:
他们两都收获了流量,只有爷浪费了时间
点赞
评论
收藏
分享
不愿透露姓名的神秘牛友
07-30 11:34
这是认真的吗?
真的很糟糕:
黑奴听了都流泪啊
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
点赞
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
百度提前批,三面被推迟一周,喜提秋招第一凉
1.1W
2
...
虾皮秋招一面
3573
3
...
他拿大厂SSP Offer打牌是什么概念啊?25届双非之光
3467
4
...
觉得研发高人一等的这辈子有了
2768
5
...
百度提前批 三面
2032
6
...
最强本科✌
1759
7
...
也是逆天了
1451
8
...
被猿辅导挂了简历,但我想说...
1405
9
...
虾皮一面凉经
1368
10
...
上班一周,工资还没拿,先欠公司两千
1338
创作者周榜
更多
正在热议
更多
#
工作中哪个瞬间让你想离职
#
66043次浏览
583人参与
#
找工作如何保持松弛感?
#
92292次浏览
1120人参与
#
中兴秋招
#
207418次浏览
2304人参与
#
如何快速融入团队?
#
19055次浏览
221人参与
#
Offer比较,你最看重什么?
#
194327次浏览
1323人参与
#
和同事相处最忌讳的是__
#
27112次浏览
257人参与
#
秋招被确诊为……
#
166730次浏览
795人参与
#
参加过提前批的机械人,你们还参加秋招么
#
86728次浏览
1417人参与
#
投格力的你,拿到offer了吗?
#
87755次浏览
586人参与
#
虾皮求职进展汇总
#
250973次浏览
1888人参与
#
你最希望上岸的公司是?
#
136114次浏览
709人参与
#
计算机专业还有必要去大厂卷吗
#
38773次浏览
184人参与
#
柠檬微趣工作体验
#
6940次浏览
40人参与
#
26届的你,投了哪些公司?
#
51360次浏览
525人参与
#
地平线求职进展汇总
#
52767次浏览
371人参与
#
通信硬件岗投递时间线
#
18981次浏览
69人参与
#
简历上的经历如何包装
#
32563次浏览
869人参与
#
我对___祛魅了
#
53561次浏览
467人参与
#
你跟室友的关系怎么样?
#
8362次浏览
124人参与
#
你遇到最难的面试题目是_
#
17731次浏览
210人参与
#
一人推荐一个值得去的通信/硬件公司
#
191738次浏览
1887人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务