[[354655]]
Redis是实无2009年发布的,到今天已经超过10岁了。实无作为必备技能之一,实无关于它也有聊不完的实无话题。本文中的实无任何一个点,都可以展开,实无完成一篇中等规模的实无文章。
交流和面试时,你需要用最精准的语言进行描述,那么本文比较适合你。
redis能力:
1. 基本概览
学习一门新语言,重要的是掌握它的基本数据结构,以及这些数据结构的API。redis的这些数据结构,就类似一门语言。
Redis数据结构
常用5种,一共10种。面试时一般回答5种即可,但其他5种是加分项。
Redis的协议
Redis是文本协议
Redis底层数据结构
数据量较小和大数据量的时候,往往不同,关注大数据量的主要结构。
跳表的关注度比较大,在Java中,可以参考类似ConcurrentSkipListMap实现。
另:Java中有序Set叫做TreeSet,但是用红黑树实现的,注意区别。
Redis持久化方式
生产环境,一般仅采用RDB模式。
O(n)指令
建议在集合大小不确定的时候,使用scan hscan sscan zscan 替代。另外,像keys这种危险命令,最好使用RENAME指令给屏蔽掉。
性能优化
扩展方式
module模式知道的人比较少,属于比较底层的开发。
2. 问题排查
3. 淘汰策略
如果你应聘的是redis dba,这道题答不出来,直接淘汰。
针对于第三种情况,有8种策略。注意,redis已经有LFU了。
如果不设置maxmemory,Redis将一直使用内存,直到触发操作系统的OOM-KILLER。
4. 集群模式
互联网建议使用Redis Cluster,外包、项目随意。
大规模
5. Redis常见问题
Redis使用场景
API举例:
缓存一致性
为什么有一致性问题?
建议使用:Cache Aside Pattern
读请求:
变更操作:
涉及到复杂的事务和回滚操作,可以把淘汰放在finally里。
问题:缓存淘汰失败!(概率很低 ,定时补偿)
缓存击穿
影响,轻微。
高流量下 大量请求读取一个失效的Key -> Redis Miss -> 穿透到DB
解决方式:采用分布式锁,只有拿到锁的第一个线程去请求数据库,然后插入缓存
缓存穿透
影响,一般。
访问一个不存在的Key(恶意攻击)-> Redis Miss -> 穿透到DB
解决方式:
缓存雪崩
影响:严重。
大量Key同时失效 | 2.Redis当机 -> Redis Miss -> 压力打到DB
解决方式:
分布式锁
redis的分布式锁,并不是那么简单。建议使用redisson的redlock。最基础的指令是setnx。
- setnx-> SET key value [EX seconds|PX milliseconds|KEEPTTL] [NX|XX] [GET]
分布式锁 关键点:
最简单的Redis分布式锁代码(不严谨)。
java端代码模拟lock和unlock。
- public String lock(String key, int timeOutSecond) {
- for (; ; ) {
- String stamp = String.valueOf(System.nanoTime());
- boolean exist = redisTemplate.opsForValue().setIfAbsent(key, stamp, timeOutSecond, TimeUnit.SECONDS);
- if (exist) {
- return stamp;
- }
- }
- }
- public void unlock(String key, String stamp) {
- redisTemplate.execute(script, Arrays.asList(key), stamp);
- }
lua脚本unlock。
- local stamp = ARGV[1]
- local key = KEYS[1]
- local current = redis.call("GET",key)
- if stamp == current then
- redis.call("DEL",key)
- return "OK"
- end
6. Redis使用
常用Java客户端
使用规范
根据公司情况自定义裁剪,没有万能的规范。更多:
这可能是最中肯的Redis规范了
springboot cache redis
Redis是多线程?
要看哪个阶段。数据操作阶段,一直是单线程的,哪怕是redis6。
作者简介:小姐姐味道 (xjjdog),一个不允许程序员走弯路的公众号。聚焦基础架构和Linux。十年架构,日百亿流量,与你探讨高并发世界,给你不一样的味道。我的个人微信xjjdog0,欢迎添加好友,进一步交流。
责任编辑:武晓燕 来源: 小姐姐味道 Redis交流面试
(责任编辑:综合)
文投控股(600715.SH):北京文创定增基金已减持17.89万股 占公司总股份的0.0096%