Redis默认最大内存处理原理
前言
最近研究redis配置时,看到很reids.conf配置文件中maxmemory默认是注释的,就好(闲)奇的查看了一下默认内存的设置。
源码
查看github源码:https://github.com/redis/redis
搜索“maxmemory”关键字查到server.c文件(一看就是启动文件)。
/* 检测到当前系统为32位,因为32最大内存为4G,在没有设置maxmemory的时候,
* 这里默认将最大内存设置为3G,并且使用noeviction淘汰策略,
* 所以不设置maxmemory时,设置maxmemory_policy也是会被覆盖的 */
if (server.arch_bits == 32 && server.maxmemory == 0) {
serverLog(LL_WARNING,"Warning: 32 bit instance detected but no memory limit set. Setting 3 GB maxmemory limit with 'noeviction' policy now.");
server.maxmemory = 3072LL*(1024*1024); /* 3 GB */
server.maxmemory_policy = MAXMEMORY_NO_EVICTION;
}
当系统不是32位时,maxmemory就是为0,redis不会对可用内存进行能判断,直到程序因无可用内存异常崩溃。
/*比如这里,执行命令时判断可用内存,如果maxmemory为0就不进行可用内存判断。*/
if (totwritten > NET_MAX_WRITES_PER_EVENT &&
(server.maxmemory == 0 || zmalloc_used_memory() < server.maxmemory) &&
!(c->flags & CLIENT_SLAVE)) break;
————————————————
版权声明:本文为CSDN博主「lizz666」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/lizz861109/article/details/109493998