不知从何开始Redis的内存淘汰策略也开始被人问及,卷!真的是太卷了。难不成要我们去阅读Redis源码吗,其实问题的答案,在Redis中的配置文件中全有,不需要你阅读源码、这个东西就是个老八股,估计问这个东西是想考察你们做的项目体量大不大。一般用 lru 就行。
找到redis安装目录,找到redis.conf文件,找到如下代码,即可配置对应的内存回收策略
maxmemory-policy noeviction
至于内存策略有哪几种,文档中也写出来了,但是用洋文写的,下面用国语翻译一下。
当Redis使用内存超过了配置文件中设置的最大内存、或者大于物理机内存,将会触发内存回收策略
这玩意我在配置文件中翻了一圈没找到对应的配置,那就肯定是要看redis源码了。我很爱看源码。但是看了下redis安装文件中的src文件,这玩意尼玛好像是用C语言写的,就好像很多人喜欢问 Synchronized 锁升级,但是这玩意的源码需要进行反编译查看,而且不是用 Java写的,叫我们怎么看呢。但是没关系,这些我都总结好了。
Redis用到的过期删除策略:惰性删除、定期删除、定时删除,这些都是前辈们的经验之谈,这玩意怎么来的?就好比Mybatis中用到了哪些设计模式,委派模式是其中的一个,同理 惰性删除、定期删除、定时删除,也是Redis用到的一部分过期删除策略。要想完全搞明白用到的所有过期删除策略,你需要把 src 文件下面所有的 .c 文件全部看一遍。
修改 redis.conf 中的如下配置即可
# RDB文件名称
dbfilename dump.rdb
# RDB文件存放路径
dir /Users/zhangzixing/Desktop/redis持久化文件
没怎么用过这些命令,浅浅的记录一下~~~
阻塞Redis所有请求,直至RDB文件生成完成,不建议使用
SAVE
开启子线程,非阻塞生成RDB文件
BGSAVE
这个读者可以跳过,我经常忘记我电脑上Redis的安装路径,这里做个记录~
redis-server /usr/local/redis-6.0.10/etc/redis.conf
config set requirepass 123456
由于 Redis 的内存数据库,CPU不会成为Redis性能的瓶颈,内存执行指令速度非常快,是单个线程去执行指令,但是别忘了,Redis 还需要对 RDB、AOF 文件进行 IO 操作,IO 操作是多线程执行的。
到此本文结束,关注不迷路,后续分享更多经验之谈~~~~