年底了,你发年终奖了么?是不是很不爽?不管是被动毕业还是主动毕业,生活还得继续是不是?
目前创新互联建站已为上千家的企业提供了网站建设、域名、网页空间、网站托管维护、企业网站设计、富源网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
作为程序员,那就离不开Redis,谁让不争气的磁盘还是那么慢呢?要过了面试这道坎,Redis必须掌握好。除了会用,还得了解它背后的原理。
为啥?因为大家现在都在养蛊。人生在世,诸多无奈。逆水行舟,不进则退。
如果你读过Redis相关的书籍,本文就帮你快速的撸一遍。没读过也不要紧,缺啥补啥。
redis能力:
学习一门新语言,重要的是掌握它的基本数据结构,以及这些数据结构的API。redis的这些数据结构,就类似一门语言。
常用5种,一共10种。面试时一般回答5种即可,但其他5种是加分项。
Redis是文本协议
数据量较小和大数据量的时候,往往不同,关注大数据量的主要结构。
跳表的关注度比较大,在Java中,可以参考类似ConcurrentSkipListMap实现。
另:Java中有序Set叫做TreeSet,但是用红黑树实现的,注意区别。
生产环境,一般仅采用RDB模式。
建议在集合大小不确定的时候,使用scan hscan sscan zscan 替代。另外,像keys这种危险命令,最好使用RENAME指令给屏蔽掉。
module模式知道的人比较少,属于比较底层的开发。
如果你应聘的是redis dba,这道题答不出来,直接淘汰。
针对于第三种情况,有8种策略。注意,redis已经有LFU了。
如果不设置maxmemory,Redis将一直使用内存,直到触发操作系统的OOM-KILLER。
互联网建议使用Redis Cluster,外包、项目随意。
具体搭建过程,请参考:《好慌,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
详细分析:Redis都要老了,你还在用什么古董客户端?
根据公司情况自定义裁剪,没有万能的规范。更多:
这可能是最中肯的Redis规范了
要看哪个阶段。数据操作阶段,一直是单线程的,哪怕是redis6。
这篇文章分析了这个过程:和 杠精 聊Redis多线程 ????
网页题目:来来,快速撸 Redis 一遍!
文章出自:http://www.csdahua.cn/qtweb/news8/252008.html
成都网站优化推广公司_创新互联,为您提供全网营销推广、营销型网站建设、小程序开发、标签优化、搜索引擎优化、网站维护
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网