一、Redis无磁盘化复制原理解析

从内存复制到内存,用socket传输。磁盘不好时,网络带宽性能好时,可以选择无磁盘化复制。无磁盘化复制目前处在试验阶段。

Redis图形化工具怎么查看磁盘空间 redis 磁盘_Redis图形化工具怎么查看磁盘空间

 配置

repl-diskless-sync yes //开启无磁盘化复制

 repl-diskless-sync-delay 5   //等待5秒钟,再开始无磁盘化同步,目的是等待所有slave服务器都连接上master服务(socket通信)

 

Redis图形化工具怎么查看磁盘空间 redis 磁盘_缓存_02

二、Redis 缓存过期处理

引子

计算机内存有限,越大越贵,Redis的高并发高性能都是基于内存的,用硬盘的话GG。

已过期的key如何处理?

设置了expire的key缓存过期了,但是服务器的内存还是会被占用,这是因为redis所基于的两种删除策略

redis有两种策略:

1. (主动)定时删除 定时随机的检查过期的key,如果过期则清理删除。(每秒检查次数在redis.conf中的hz配置),hz默认是10

Redis图形化工具怎么查看磁盘空间 redis 磁盘_Redis图形化工具怎么查看磁盘空间_03

 

2. (被动)惰性删除 当客户端请求一个已经过期的key的时候,那么redis会检查这个key是否过期,如果过期了,则删除,然后返回一个nil。这种策略很友好,不会有太多的损耗,但是内存占用会比较高。 所以,虽然key过期了,但是只要没有被redis清理,那么其实内存还是会被占用着的。

三、内存淘汰机制

那么如果内存被Redis缓存占用慢了咋办?在一个服务器上,还有其他中间件,如tomcat、nginx等也都会用到内存。

针对以上问题, redis有自己的内存淘汰机制

内存占满了,可以使用硬盘,来保存,但是没意义,因为硬盘没有内存快,会影响redis性能。 所以,当内存占用满了以后,redis提供了一套缓存淘汰机制:MEMORY MANAGEMENT

maxmemory :当内存已使用率到达,则开始清理缓存

* noeviction:旧缓存永不过期,新缓存设置不了,返回错误

* allkeys-lru:清除最少用的旧缓存,然后保存新的缓存(推荐使用)

* allkeys-random:在所有的缓存中随机删除(不推荐)

* volatile-lru:在那些设置了expire过期时间的缓存中,清除最少用的旧缓存,然后保存新的缓存

* volatile-random:在那些设置了expire过期时间的缓存中,随机删除缓存

* volatile-ttl:在那些设置了expire过期时间的缓存中,删除即将过期的

Redis图形化工具怎么查看磁盘空间 redis 磁盘_缓存_04