Redis内存限制配置和算法总结

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011676300/article/details/82117323

  本文所讲的Redis版本是4.0.9
  在使用Redis时,可以为键设计过期时间,但是如果使用的业务量较大,并且设置的过期时间较长,导致键未能及时删除,那么便会导致机器内存不足的情况出现.另一方面,如果为了降低内存不足的情况出现的概率,将缓存时间设置过低,那么也会降低缓存命中率.

  因此还需要对其使用的内存进行限制,在Redis配置文件中,有两个参数可以进行配置.

//限制的内存大小
maxmemory <bytes>
//删除键策略
maxmemory-policy 
策略 说明
volatile-lru 使用LRU算法删除一个设置过期时间的建
allkeys-lru 使用LRU算法删除一个键
volatile-lfu 使用LFU算法删除一个设置过期时间的建
allkeys-lfu 使用LFU算法删除一个键
volatile-random 随机删除一个设置过期时间的建
allkeys-random 随机删除一个键
volatile-ttl 删除离过期时间最近的一个键
noeviction 不删除任何键,向写操作返回错误信息
//最近很少使用
LRU means Least Recently Used
//使用频率较低
LFU means Least Frequently Used

  当Redis所占用的内存达到这个限制值,那么就会根据删除键策略来删除相关的键.如果策略设置为noeviction,Redis当内存不足时,当时用set / lpush 等指令添加数据时,将会返回报错信息.此时,只能读取.
  

猜你喜欢

转载自blog.csdn.net/u011676300/article/details/82117323
今日推荐