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

Linux内存回收和交换

前言 Linux的swap相关部分代码从2.6早期版本到现在的4.6版本在细节之处已经有不少变化。本文讨论的swap基于Linux 4.4内核代码。...Linux内存管理是一套非常复杂的系统,而swap只是其中一个很小的处理逻辑。希望本文能让读者了解Linux对swap的使用大概是什么样子。...另外,Linux内核使用cache的策略虽然是不用白不用,内核会使用内存中的page cache对部分文件进行缓存,以便提升文件的读写效率。...那么如何描述内存使用的压力呢?Linux内核使用水位标记(watermark)的概念来描述这个压力情况。Linux内存的使用设置了三种内存水位标记,high、low、min。...Linux内存分成多个区,主要有直接访问区(DMA)、一般区(Normal)和高端内存区(HighMemory)。内核对内存不同区域的访问因为硬件结构因素会有寻址和效率上的差别。

4.6K52

图解 | Linux内存回收之LRU算法

如下图所示: 但内存资源是有限的,随着系统中运行的进程越来越多,系统中可用的内存就会越来越少。那么,当可用内存不足时,Linux 内核是怎么处理的呢?...内存回收工作主要包括以下几个步骤: 内核为了加速某些操作(如文件 I/O),会对操作的结果进行缓存(如文件页缓存),而缓存使用的内存是可以被回收的。所以,当可用内存不足时,首先会回收内核中的缓存。...由于回收内存的方式有三种,所以本文重点以 swap 机制作为分析对象,来介绍当内存不足时,内核是怎么进行内存回收工作的。...LRU算法状态流转 我们最后以一张状态流转图来描述 LRU 算法的过程: 三、总结 本文主要介绍了 Linux 内核内存回收过程中使用的 LRU 算法的原理,在下一篇文章中,我们将会介绍 Linux...内核是如何实现内存回收的,有兴趣的敬请期待。

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

聊聊Linux内核的内存回收上篇

概述 内存回收是把已经使用过的的物理页帧重新放回到内核中的buddy系统(buddy系统用于申请空闲物理页帧的子系统)管理中,解决内存紧张的问题;内存回收的页帧包括未修改的文件页帧、修改且完成同步的文件页帧...内核对所有用户态进程消耗的RAW内存总量不做严格的约束,当系统负载相对较低的时候,内存大部分被磁盘高速缓存使用,随着系统负载增大,系统进程使用的内存越来越多,磁盘的高速缓存占用的内存就会被缩小,内存页帧的回收必须在消耗所有空闲页帧之前进行...slab分配器在频繁申请和释放的情况下效率比较高 基于LRU页帧链表 内存页帧是有映射的,映射到一个或者多个进程的虚拟空间。内核一般用内存页帧的引用次数来表示页帧的活跃程度。...页帧回收会按照几个原则来进行内存页帧的回收,第一是回收高速磁盘缓存的页帧;第二回收睡眠时间较长的进程中的页帧;第三是回收共享页帧的引用全部清除;第四回收LRU链表中未使用的 页帧回收的过程页分为直接回收和定期回收...直接回收是发生在分配页帧时候发现空闲页帧不足的情况下。直接回收和定期回收底层都是走相同的逻辑,但是直接回收是实在紧急情况下进行,必须做到回收到足够的页帧。

1.7K30

内存回收

前言: 前文《内存映射技术分析》描述了虚拟内存的管理、内存映射;《物理内存管理》介绍了物理内存管理。 本篇介绍一下内存回收内存回收应该是整个Linux内存管理上最难理解的部分了。...分析: 1,PFRA Page Frame Reclaim Algorithm,Linux内存回收算法。 不过,PFRA和常规的算法不同。...2,watermark 如前文《物理内存管理》提到,每个memory zone都有watermark,如果低于了watermark,Linux就考虑回收内存了。...只是说,如果内存不够了,linux会尝试回收,尽量满足。 回收的时候,如果实在回收不到了,linux会选择最差的策略---杀掉一部分进程。...后记: 虚拟内存的管理,内存映射,物理内存管理,内存回收,差不多就是Linux内存管理的主要功能了。 Good Luck~

3.2K100

JVM-09自动内存管理机制【内存分配和回收策略】

虚拟机提供-XX:+PrintGCDetails参数,告诉虚拟机在发生垃圾收集行为时打印内存回收日志,并且在进程退出的时候输出当前的内存各区域分配情况。...而堆内存 6487K->6303K基本没有发生变化,是因为 object1,object2,object3都是存活的对象,无法被GC回收。...---- 理论 现在商用虚拟机都采用分代收集的思想来管理内存,那么内存回收就必须能识别哪些对象应该放在新生代,哪些对象应该放在老年代。 为了做到这一点,虚拟机给每个对象定义了一个对象年龄计数器。...堆内存新生代可用空间为9M, 首先在堆内存中分配了object1 256KB的内存,紧接着分配了object2 占用4M内存空间,此时新生代中还剩余8M-( 256KB+4M ) 的内存空间, object3...将object3置为null(这个时候已经没有引用,对象已经死亡,GC可以回收),分配object4 的时候又触发了一次Minor GC 。

27030

Redis内存回收策略

Redis会因为内存不足而产生错误,也会因为回收过久而导致系统长期的停顿,因此了解掌握Redis的回收策略十分重要。...当Redis的内存达到规定的最大值时,可以进行配置进行淘汰键值,并且将一些键值对进行回收。 我们打开Redis安装目录下的redis.conf文件。...noeviction:不淘汰任何键值对,当内存满时,如果进行读操作,例如get命令,它将正常工作,而做写操作,它将返回错误,也就是说,当Redis采用这个策略内存达到最大的时候,它就只能读不能写了。...回收超时策略的缺点是必须指明超时的键值对,这会给程序开发带来一些设置超时的代码,增加刘开发者的工作量。对所有的键值对进行回收,有可能把正在使用的键值对删掉,增加了存储的不稳定性。...对于垃圾回收的策略,还需要控制回收的时间。

2.4K20

Linux 内存中的Cache,真的能被回收么?

Linux内存管理中,这里的buffer指Linux内存的:Buffer cache。这里的cache指Linux内存中的:Page cache。翻译成中文可以叫做缓冲区缓存和页面缓存。...如何回收cache? Linux内核会在内存将要耗尽的时候,触发内存回收的工作,以便释放出内存给急需内存的进程使用。 一般情况下,这个操作中主要的内存释放都来自于对buffer/cache的释放。...是在其文件被删除的时候,如果不删除文件,无论内存耗尽到什么程度,内核都不会自动帮你把tmpfs中的文件删除来释放cache空间。 这是我们分析的第一种cache不能被回收的情况。...使用shmget方式申请的共享内存会占用cache空间,除非共享内存被ipcrm或者使用shmctl去IPC_RMID,否则相关的cache空间都不会被自动释放。...使用mmap方法申请的MAP_SHARED标志的内存会占用cache空间,除非进程将这段内存munmap,否则相关的cache空间都不会被自动释放。

2.5K110

Linux 内存中的 Cache 真的能被回收么?

Linux内存管理中,这里的buffer 指 Linux 内存的:Buffer cache。这里的 cache 指 Linux 内存中的:Page cache。...如何回收 cache? Linux 内核会在内存将要耗尽的时候,触发内存回收的工作,以便释放出内存给急需内存的进程使用。...如果不删除文件,无论内存耗尽到什么程度,内核都不会自动帮你把 tmpfs 中的文件删除来释放cache空间。 这是我们分析的第一种 cache 不能被回收的情况。...3、使用 shmget 方式申请的共享内存会占用 cache 空间,除非共享内存被 ipcrm 或者使用 shmctl 去 IPC_RMID,否则相关的 cache 空间都不会被自动释放。...4、使用 mmap 方法申请的 MAP_SHARED 标志的内存会占用 cache 空间,除非进程将这段内存 munmap,否则相关的 cache 空间都不会被自动释放。

5.2K50

php内存泄漏,内存溢出,垃圾回收

php 在每次请求结束后自动释放内存,有效避免了常见场景下内存泄露的问题,然而实际环境中因某些扩展的内存管理没有做好或者 php 代码中出现循环引用导致未能正常释放不用的资源。...当一个 php-fpm 进程被销毁后,它所占用的所有内存都会被回收。 垃圾回收 一、概念 垃圾回收机制是一种动态存储分配的方案。它会自动释放程序不再需要的已分配的内存块。...垃圾回收机制可以让程序员不必过分关心程序内存分配,从而将更多的精力投入到业务逻辑。...但是当两个或多个对象互相引用形成环状后,内存对象的计数器则不会消减为0;这时候,这一组内存对象已经没用了,但是不能回收,从而导致内存泄露的现象。...php5.3开始,使用了新的垃圾回收机制,在引用计数基础上,实现了一种复杂的算法,来检测内存对象中引用环的存在,以避免内存泄露。

3.2K20

自动内存管理系统实操手册——Golang垃圾回收

导语 | 现代高级编程语言管理内存的方式分自动和手动两种。...手动管理内存的典型代表是C和C++,编写代码过程中需要主动申请或者释放内存;而PHP、Java 和Go等语言使用自动内存管理系统,由内存分配器和垃圾收集器来代为分配和回收内存,其中垃圾收集器就是我们常说的...上期在《自动内存管理系统实操手册——Java垃圾回收篇》一文中向大家分享了Java垃圾回收算法,今天腾讯后台开发工程师汪汇接着向大家分享 Golang 垃圾回收算法。...目前常见的垃圾回收算法在上篇《自动内存管理系统实操手册——Java垃圾回收篇》一文中的“垃圾收集算法”部分已有介绍,而Go使用的是标记清除算法,这是一种非常基础和常见的垃圾收集算法,于1960年被J.McCarthy...推荐阅读 自动内存管理系统实操手册——Java垃圾回收篇 百万级库表能力!这个MongoDB为什么可以这么牛? Serverless 在大厂都怎么用?

66650

weakSet与js内存回收

$ node --expose-gc index.js // 第一次垃圾回收,当前内存使用情况:1.76MB // 第二次垃圾回收,当前内存使用情况:18.54MB // 第三次垃圾回收,当前内存使用情况...toFixed(2)}MB`); }, 100) // 结果 // 第一次垃圾回收,当前内存使用情况:1.77MB // 第二次垃圾回收,当前内存使用情况:18.54MB // 第三次垃圾回收,当前内存使用情况...:18.54MB // 第N次垃圾回收,当前内存使用情况:18.55MB // ... // 第N次垃圾回收,当前内存使用情况:2.00MB // 第N次垃圾回收,当前内存使用情况:2.01MB ---...- 虽然,javascript引擎会自动优化内存,但是作为开发者还是应该适当关注一下内存的使用情况,以防止极端的情况内存释放不及时。...,当前内存使用情况:1.76MB // 第二次垃圾回收,当前内存使用情况:18.54MB, // 当前Map的长度: 1 // 第三次垃圾回收,当前内存使用情况:18.54MB, // 当前Map

1.3K20

Go 内存管理 -- 垃圾回收

本篇要说的就是垃圾回收,常见的垃圾回收算法有标记-清除、标记整理、复制,然后在这些算法基础上有分为分代&非分代回收,这些算法都非常优秀,只是面对的场景不同罢了,但是要是想透彻的理解垃圾回收,看Java中的实现再合适不过了...,如果能对于Java中的垃圾回收非常熟悉,理解go的垃圾回收将非常简单。...image.png 很显然如果使用标记清除算法: 1、确定标记的起点GCRoot 2、存在一定的内存碎片 3、效率相对于复制、整理 效率要稍微高一些 但标记清除是最常见的垃圾回收算法,Java...强制回收 因为系统启动或者短时间内大量分配对象这些原因,会将垃圾回收的gc_trigger(垃圾回收的触发器)的标准瞬间推高。当服务正常后,活跃对象远小于这个阈值,造成垃圾回收无法触发。...关于整体回收这一块儿内容,大家有兴趣可以看一下源码。 关于go的垃圾回收暂时就先介绍这么多。 关于go的内存管理后续会单独出一个系列,所以本系列仅仅阐述了一个内存管理的梗概和基础概念。

94541

JVM内存分配与回收

1.3 长期存活的对象将进入老年代 既然虚拟机采用了分代收集的思想来管理内存,那么内存回收时就必须能识别那些对象应放在新生代,那些对象应放在老年代中。...第二次标记 如果这个对象被判定为有必要执行finalize()方法,那么这个对象将会被放置在一个名为:F-Queue的队列之中,并在稍后由一条虚拟机自动建立的、低优先级的Finalizer线程去执行。...它可以将内存分为大小相同的两块,每次使用其中的一块。当这一块的内存使用完后,就将还存活的对象复制到另一块去,然后再把使用的空间一次清理掉。这样就使每次的内存回收都是对内存区间的一半进行回收。...4.垃圾收集器 如果说收集算法是内存回收的方法论,那么垃圾收集器就是内存回收的具体实现。 虽然我们对各个收集器进行比较,但并非为了挑选出一个最好的收集器。...这种使用Region划分内存空间以及有优先级的区域回收方式,保证了GF收集器在有限时间内可以尽可能高的收集效率。

1.5K20

自动内存管理系统实操手册——Java垃圾回收

导语 | 现代高级编程语言管理内存的方式分自动和手动两种。...手动管理内存的典型代表是C和C++,编写代码过程中需要主动申请或者释放内存;而PHP、Java 和Go等语言使用自动内存管理系统,由内存分配器和垃圾收集器来代为分配和回收内存,其中垃圾收集器就是我们常说的...而 Java 堆和方法区则不同,一个接口中的多个实现类需要的内存可能不同,一个方法中的多个分支需要的内存也可能不一样,我们只有在程序处于运行期间时才能知道会创建哪些对象,这部分内存的分配和回收都是动态的...缺点: 1.空间问题,易产生内存碎片,当为一个大对象分配空间时可能会提前触发垃圾回收(例如,对象的大小大于空闲表中的每一块儿大小但是小于其中两块儿的和)。...使用复制算法,回收过程中就不会出现内存碎片,也提高了内存分配和释放的效率。 适用场合:存活对象较少的情况下比较高效、用于年轻代(即新生代)。

51050

内存分配与回收策略

主要有以下策略: 对象优先在 Eden 区分配 大对象直接进入老年代 长期存活的对象将进入老年代 动态对象年龄判定 空间分配担保 这个内容之前在 垃圾收集器与内存分配策略 里面 ,想想还是单独列一篇算了...新生代 GC(Minor GC):指发生在新生代的垃圾收集动作,因为 Java 对象大多具备朝生夕灭的特性,所以 Minor GC 非常频繁,一般回收速度也比较快。...二、大对象直接进入老年代 大对象是指需要大量连续内存空间的 Java 对象,例如很长的字符串以及数组等。...这样可以避免在 Eden 区以及两个 Survivor 区之间发生大量的内存复制。 PretenureSizeThreshold 这个参数只对 Serial 和 ParNew 两种收集器有效。...Copyright: 采用 知识共享署名4.0 国际许可协议进行许可 Links: https://lixj.fun/archives/内存分配与回收策略

81910
领券