- 论坛徽章:
- 6
|
回复 1# chenxs03
看到材料上说,linux内存页面回收是周期性的运行的。
那么,内存分配时如果找不到足够的内存,系统回怎么处理呢?
1 回收内存。
2 跳过这个进程,等周期性的页面回收之后再处理。
3 出错
除了“核心交换后台进程”负责回收内存以外还有别的回收机制吗?
内核申请内存到最后的核心函数就是__alloc_pages:
首先在对应的zone(DMA,NORMAL,HIGH,....)中尝试分配,如果分配成功返回;
调用wake_all_kswapd唤醒内存回收进程,并修改分配的flags,同时降低水印值,再一次尝试分配,如果分配成功返回;
如果设置了ALLOC_NO_WATERMARKS,那么内核会忽略水印值,再一次尝试分配,如果分配成功返回;
如果进程禁止睡眠或者设置了PF_MEMALLOC或者进程设置了TIF_MEMDIE,那么只能分配失败,返回;
进入同步回收状态,直接调用try_to_free_pages去回收内存,然后再一次调用get_page_from_freelist尝试分配,如果分配成功返回;
如果回收了部分内存,内核会再次尝试直接回收内存,并尝试分配,如果分配成功返回;
如果没有任何内存可以回收,那么只能放弃了。。。(如果开启了oom,这里可能会触发oom) |
|