首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么删除数据后,Redis内存占用依然很高?

前言 上周刚来了个应届小师弟,组长说让我带着,周二问了我这样一个问题:师兄啊,我用top命令看了下服务器的内存占用情况,发现Redis内存占用严重,于是我就删除了大部分不用的keys,为什么内存占用还是很严重...第二个原因其实理解起来很简单,键值对的修改或者删除肯定会造成空间的扩容或者释放; 一方面,如果修改后的键值对变大或者变小了,势必会将占用的空间扩大或者释放不用的空间,如下图: ?...上图中键值对修改后变小了,从原来的10个字节变成了7个字节,从而释放了3个字节,此时剩余了5个字节的空闲空间。 另一方面,如果键值对删除了,则会释放掉占用的空间,形成空闲空间。...以上两个参数控制了清理过程中的CPU时间占比,保证了正常处理请求不受影响 总结 本文以师弟的一个疑问开头介绍了删除数据导致内存占用还是很高的原因是存在内存碎片,导致内存碎片大致分为两个原因,如下: 内存分配策略局限性...键值对的修改、删除导致了内存的扩容或者释放,导致多余的不连续的空闲内存块。

1.3K20

师兄,为什么删除数据后,Redis内存占用依然很高?

前言 上周刚来了个应届小师弟,组长说让我带着,周二问了我这样一个问题:师兄啊,我用top命令看了下服务器的内存占用情况,发现Redis内存占用严重,于是我就删除了大部分不用的keys,为什么内存占用还是很严重...第二个原因其实理解起来很简单,键值对的修改或者删除肯定会造成空间的扩容或者释放; 一方面,如果修改后的键值对变大或者变小了,势必会将占用的空间扩大或者释放不用的空间,如下图: ?...上图中键值对修改后变小了,从原来的10个字节变成了7个字节,从而释放了3个字节,此时剩余了5个字节的空闲空间。 另一方面,如果键值对删除了,则会释放掉占用的空间,形成空闲空间。...以上两个参数控制了清理过程中的CPU时间占比,保证了正常处理请求不受影响 总结 本文以师弟的一个疑问开头介绍了删除数据导致内存占用还是很高的原因是存在内存碎片,导致内存碎片大致分为两个原因,如下: 内存分配策略局限性...键值对的修改、删除导致了内存的扩容或者释放,导致多余的不连续的空闲内存块。

1.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java虚拟机--虚拟机内存区域Java虚拟机内存区域

    Java虚拟机内存区域 Java程序在JVM虚拟机中运行,当我们一个类被加载到虚拟机中时,JVM会给该类分配具体的内存空间/内存地址,而这被分配的区域就是Java虚拟机运行时内存区域。...虚拟机内存。...而运行时常量池,则是Java虚拟机在完成类装载操作后,将class文件中的常量池载入到内存中,并保存在方法区中,我们常说的常量池,就是指方法区中的运行时常量池。...运行时常量池 运行时常量池,是Java虚拟机在完成类装载操作后,将class文件中的常量池载入到内存中,保存在方法区中,我们常说的常量池,就是指方法区中的运行时常量池。...当类被加载到内存中后,Java虚拟机会将class常量池中的内容存放到运行时常量池中,每个类都保存在运行时常量池中。

    2.1K80

    Redis删除数据后,为什么内存占用率还是很高?

    在使用 Redis 时,我们经常会遇到这样一个问题:明明做了数据删除,数据量已经不大了,为什么使用 top 命令查看时,还会发现 Redis 占用了很多内存呢?...实际上,这是因为,当数据删除后,Redis 释放的内存空间会由内存分配器管理,并不会立即返回给操作系统。所以,操作系统仍然会记录着给 Redis 分配了大量内存。...这是因为,内存分配器一般是按固定大小来分配内存,而不是完全按照应用程序申请的内存空间大小给程序分配。...如果应用 A 不再保存新数据,那么,这里多出来的 2 字节空间就是内存碎片了,如下图所示: ? 第二个外因是,这些键值对会被修改和删除,这会导致空间的扩容和释放。...具体来说,一方面,如果修改后的键值对变大或变小了,就需要占用额外的空间或者释放不用的空间。另一方面,删除的键值对就不再需要内存空间了,此时,就会把空间释放出来,形成空闲空间。 ?

    1.9K21

    Redis删除数据后,为什么内存占用率还是很高?

    这里先说答案 实际上,这是因为,当数据删除后,Redis 释放的内存空间会由内存分配器管理,并不会立即返回给操作系统。所以,操作系统仍然会记录着给 Redis 分配了大量内存。...,并不会立即返回给操作系统,是因为采用了一种称为“惰性删除”的机制,即在数据被删除之后,并不会立即释放内存空间,而是等到有新数据需要使用该空间时才会释放。...为保证A的内存空间连续性,B的数据拷贝到了第二阶段D释放出来的那个字节位置C修改后删除了2个字节空间可以看出经过一系列对数据的修改,C和D之间有2字段内存空间,此时多出来2字节空间就是内存碎片。...朋友,希望本文对你有帮助~欢迎点赞 、收藏 、关注 三连支持一下~知道的越多,不知道的也越多,我是小许,下期见~参考:Redis删除数据后,为什么内存占用率还是很高?...-腾讯云开发者社区-腾讯云Redis 的数据被删除,内存占用还这么大?

    708101

    JVM虚拟机内存

    Java虚拟机栈:java方法执行的内存模型,每个方法被执行时都会创建一个栈帧,存储局部变量表,操作栈,动态链接,方法出口等信息。...本地方法栈:Native方法服务,在hotspot虚拟机中和java虚拟机栈合二为一。 线程共享 java堆:存放对象实力,几乎所有的对象实例及其属性都在这里分配内存。...方法区:存储已经被虚拟机加载的类信息,常量,静态变量,JIT编译后的代码等数据,也称作永久代。...经过YGC后,如果eden还放不下对象,则直接分配到老年代。 对象访问 句柄访问:通过栈本地变量表,找到堆中对象实例指针,根据指针在堆中找到实例数据,在方法区中找到对象类型数据。...outfomemoryerror:虚拟机在扩展栈时无法申请到足够的内存空间,一般可以通过不停创建线程触发这种OOM。

    62920

    服务器删除文件后磁盘空间没有立刻释放问题

    服务器删除文件后磁盘空间没有立刻释放问题业务场景发现一台服务器的磁盘空间不足,需要进行处理,登录后发现磁盘使用率已经100%,操作删除了一些文件和日志信息后,查看空间仍然没有变化。...而我删除的是nginx的访问日志文件,在删除的时候该文件正在被使用。 三、解决办法首先获得一个已经被删除的可是仍然被应用程序占用的文件列表。操作如下:\1....四、删除原理一般来说,不会出现删除文件后空间不释放的情况,但是也存在例外,比如文件被进程锁定,或者有进程在使用这个文件,例如输出日志文件,要了解这个问题,就需要知道Linux下文件的存储机制和存储结构。...指针位于文件系统的meta-data中,数据被删除后,指针被清除,而数部分还是存储在磁盘中,只不过数据对应的指针被清除后,文件数据部分占用的空间就可以被覆盖了。...之所以出现删除大文件后,空间还没有释放,就是因为有进程一直在使用这个文件的指针,日志文件的服务还在运行,导致虽然删除了日志大文件,但文件对应的指针部分由于被进程锁定,并未从meta-data中清除,而由于指针并未被删除

    88110

    Java虚拟机内存管理(一)—内存划分

    ——《深入理解Java虚拟机:JVM高级特性与最佳时实践(第二版)》周志明 Java 虚拟机作为运行 Java 程序抽象出来的计算机,具有内存管理的能力,像内存分配、垃圾回收等这些相关的内存管理问题...1、内存划分 内存是计算机中运行系统和软件的场所,而内存划分是 Java 虚拟机管理内存中人为添加的概念,是为了更好的描述 Java 虚拟机对内存的管理。...下图中的的运行时数据区域即是 Java 虚拟机所管理的内存区域。 ? 内存划分.png 1.1 程序计数器 在 CPU 的寄存器中有指令计数器,而在 Java 虚拟机内存管理中也有类似的程序计数器。...1.5 方法区 同 Java 堆一样,方法区也是各个线程共享的区域,它用于存储已经被虚拟机加载过的类信息、常量、静态变量、即时编译器编译后的代码等数据。...1.6 直接内存 直接内存并不在 Java 虚拟机管理的内存区域内,也不是 Java 虚拟机规范中定义的内存区域。

    86751

    共享内存删除的陷阱

    进程脱离共享内存区后,数据结构 shmid_ds 中的 shm_nattch 就会减 1 。...但是共享段内存依然存在,只有 shm_attch 为 0 后,即没有任何进程再使用该共享内存区,共享内存区才在内核中被删除。一般来说,当一个进程终止时,它所附加的共享内存区都会自动脱离。...如果共享内存已经与所有访问它的进程断开了连接,则调用IPC_RMID子命令后,系统将立即删除共享内存的标识符,并删除该共享内存区,以及所有相关的数据结构; 如果仍有别的进程与该共享内存保持连接,则调用IPC_RMID...子命令后,该共享内存并不会被立即从系统中删除,而是被设置为IPC_PRIVATE状态,并被标记为”已被删除”(使用ipcs命令可以看到dest字段);直到已有连接全部断开,该共享内存才会最终从系统中消失...所以,可以确知, 在对共享内存删除之后不可能再有新的连接,则执行删除操作是安全的;否则,在删除操作之后如仍有新的连接发生,则这些连接都将可能失败!

    1.4K20

    解决云服务器开机后,内存与实际不符的问题

    起因 最近因为搭建scutosc的论坛,买了一台新的腾讯云的2核4G的服务器,但是开机后发现htop命令显示内存只有3.3G: 我觉得很神奇,因为我另一台腾讯云的4核4G的机器,开机之后可用为3.8G。...2G~16G之间的时候,kdump使用512M内存!...[1][2] 那我能不能把kdump预留的内存调小一点呢?...使用以下命令能够查看内核dump所需的内存页面数量: sudo makedumpfile --mem-usage /proc/kcore 可以看到内核dump需要使用的是100038个页,大约390M内存...default/grub文件,把crashkernel参数删掉,关掉kdump.然后使用以下命令,更新grub参数: sudo grub-mkconfig -o /boot/grub/grub.cfg 接着重启服务器即可生效

    99111

    KVM 虚拟机内存调整

    KVM 建立好的虚拟机也可以调整预设的内存大小,本文记录修改过程。 简介 假设当前已经存在 KVM 虚拟机 foobar 修改内存大小需要动用 virsh 命令。...基本步骤: 关闭虚拟机 调整虚拟机配置参数 重启虚拟机 调整使用的内存大小 验证是否成功 virsh 修改虚拟机内存 查看内存大小 1 virsh dominfo foobar 输出结果: 1234567891011121314...3g,即 3145728 KB 关闭虚拟机 1 virsh shutdown foobar 输出结果: 1 Domain foobar is being shutdown 修改虚拟机配置信息...启动虚拟机 我使用了 Virtual Machine Manager 重启了虚拟机,总之就是用各种方式启动虚拟机 查看当前内存 1234567891011121314151617 $ virsh dominfo...apparmorSecurity DOI: 0Security label: libvirt-d344441b-aeb3-4e6c-916d-c22edee5d234 (enforcing) 设置内存大小

    17610

    Java虚拟机内存初探

    在Java虚拟机规范中,对这个区域规定了两种异常状况:如果线程请求的栈深度大于虚拟机所允许的深度,将抛出StackOverflowError异常;如果虚拟机栈可以动态扩展(当前大部分的Java虚拟机都可动态扩展...,只不过Java虚拟机规范中也允许固定长度的虚拟机栈),如果扩展时无法申请到足够的内存,就会抛出OutOfMemoryError异常。...附加信息 虚拟机规范允许具体的虚拟机实现增加一些规范里没有描述的信息到栈帧中,例如与高度相关的信息,这部分信息完全取决于具体的虚拟机实现。...Java中的堆是用来存储对象本身的以及数组(当然,数组引用是存放在Java栈中的),几乎所有的对象实例都在这里分配内存。...五、方法区 方法区(Method Area)与Java堆一样,是各个线程共享的内存区域,它用于存储已被虚拟机加载的类信息、常量、静态变量、以及编译器编译后的代码等。

    44320
    领券