前言
内存的基本知识,将在操作系统篇中详细介绍,这里只说明如何排查问题。
正文
内存的分配和回收:
在malloc 是c 标准库中的内存分配函数,对应到系统调用上,有两种实现方式,一种是brk()和 mmap()
对于小块内存,小于128k 使用brk来分配,也就是通过移动堆栈的位置来分配内存。这些内存释放后,不会立即归还给系统,而是缓存起来。
大块内存,使用mmap()分配,在文件映射段找一块空闲内存分配出去。
brk() 方式的缓存,可以减少缺页异常的发生,提高内存访问效率。不过这些内存没有归还系统,在内存工作繁忙时, 频繁的内存分配和稀释会造成内存碎片。
而mmap() 方式分配的内存,会释放时直接规划系统,所以每次mmap 都会发生缺页异常。在内存工作繁忙时,频繁的内存分配导致大量的缺页异常,使内核的管理负担增大。
那么就到了内存不足的情况:
-
回收缓存,比如使用lru算法,回收最近使用最少的内存页面
-
回收不常用访问的内存,把不常用的内存通过交互分区直接写道磁盘中。
-
杀死进程,内存紧张时,系统会通过oom,直接杀死占用大量内存的进程。
第一种好理解,就是回收内存,在操作系统篇会介绍的比较详细。
第二种,回收不常用的内存,会用到交换分区。swap 其实就是把一块磁盘空间当作内存来用。它可以把进程暂不用的磁盘写入到内存中。
第三种是oom。
-
一个进程消耗的内存越大,oom_score 就越大。
-
一个进程运行占用的cpu越多,oom_score 就越小。
oom_adj 的范围 是[-17,15],数值越大,表示进程越容易被oom杀死。数值越小,表示进程越不容易被oom杀死,-17表示禁用oom。
一般情况下,查看内存的方式为
标签:缓存,oom,自我,内存,linux,进程,磁盘,分配 From: https://www.cnblogs.com/aoximin/p/17455460.html