原文  http://blog.tanteng.me/2016/03/redis-maxmemory/

Redis需要设置最大占用内存吗?如果Redis内存使用超出了设置的最大值会怎样?

设置Redis最大占用内存

Redis设置最大占用内存,打开redis配置文件,找到如下段落,设置maxmemory参数,maxmemory是bytes字节类型,注意转换。修改如下所示:

# In short... if youhaveslavesattacheditissuggestedthatyouset a lower # limitfor maxmemorysothatthereissomefreeRAMonthesystemfor slave # outputbuffers (butthisisnotneededif thepolicyis 'noeviction'). # # maxmemory <bytes> maxmemory 268435456 

本机服务器redis配置文件路径:/etc/redis/6379.conf,由于本机自带内存只有1G,一般推荐Redis设置内存为最大物理内存的四分之三,所以设置0.75G,换成byte是751619276.

可以在CentOS下输入命令:find / -name redis查找redis目录:

[root@iZ94r80gdghZ ~]# find / -name redis

/usr/share/nginx/html/blog.tanteng.me/wp-content/cache/supercache/blog.tanteng.me/tag/redis

/etc/redis

/var/redis

Redis配置文件一般在etc下的redis安装目录下。

Redis使用超过设置的最大值

如果Redis的使用超过了设置的最大值会怎样?我们来改一改上面的配置,故意把最大值设为1个byte试试。

# outputbuffers (butthisisnotneededif thepolicyis 'noeviction'). # # maxmemory <bytes> maxmemory 1 

打开debug模式下的页面,提示错误:OOM command not allowed when used memory > ‘maxmemory’.

设置了maxmemory的选项,redis内存使用达到上限。可以通过设置LRU算法来删除部分key,释放空间。默认是按照过期时间的,如果set时候没有加上过期时间就会导致数据写满maxmemory。

如果不设置maxmemory或者设置为0,64位系统不限制内存,32位系统最多使用3GB内存。

LRU是Least Recently Used 近期最少使用算法。

  1. volatile-lru -> 根据LRU算法生成的过期时间来删除。
  2. allkeys-lru -> 根据LRU算法删除任何key。
  3. volatile-random -> 根据过期设置来随机删除key。
  4. allkeys->random -> 无差别随机删。
  5. volatile-ttl -> 根据最近过期时间来删除(辅以TTL)
  6. noeviction -> 谁也不删,直接在写操作时返回错误。

如果设置了maxmemory,一般都要设置过期策略。打开Redis的配置文件有如下描述,Redis有六种过期策略:

# volatile-lru -> removethekeywithanexpireset usinganLRUalgorithm # allkeys-lru -> removeanykeyaccordinglytotheLRUalgorithm # volatile-random -> remove a randomkeywithanexpireset # allkeys-random -> remove a randomkey, anykey # volatile-ttl -> removethekeywiththenearestexpiretime (minorTTL) # noeviction -> don't expireatall, justreturn anerroronwriteoperations 

那么打开配置文件,添加如下一行,使用volatile-lru的过期策略:

maxmemory-policyvolatile-lru

保存文件退出,重启redis服务。

info命令查看Redis内存使用情况

如服务器Redis所在目录:/usr/local/redis-3.0.7/src

在终端输入./redis-cli,打开Redis客户端,输入INFO命令。