Redis默认最大内存是如何处理的?

Redis在32位系统中,默认最大内存为3GB并采用noeviction淘汰策略,而在64位系统中,如果不设置maxmemory,则不会限制内存使用,直至系统因内存不足而崩溃。在写操作时,如果maxmemory为0且内存未超过限制,才会继续执行。
摘要由CSDN通过智能技术生成

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值