0

0

swap 使用率持续偏高但 free -h available 很多的 overcommit 场景

冷漠man

冷漠man

发布时间:2026-01-21 18:45:51

|

246人浏览过

|

来源于php中文网

原创

Linux中swap使用率高但available内存充足,根本原因是内核启用overcommit且vm.swappiness偏高,导致内核主动换出闲置匿名页,而available仅表示可立即分配的物理内存,并不阻止swap行为。

swap 使用率持续偏高但 free -h available 很多的 overcommit 场景

这其实是 Linux 内存管理中一个常见但容易误解的现象:swap 使用率高,但 free -h 显示的 available 内存却很充足。根本原因往往不是物理内存真的不足,而是内核启用了 overcommit,且工作负载触发了内核的 swap 倾向性策略(尤其是 vm.swappiness 设置偏高 + 有大量匿名页被回收)。

为什么 available 多,swap 还在用?

Linux 的 available 是内核估算的、**可立即用于新进程的物理内存总量**,它包含:未使用的 page cache、可快速回收的 slab、以及部分可换出的匿名页(只要 swap 空间就绪)。也就是说,“available 高”只说明系统当前不缺内存来启动新任务,不代表内核不会主动把某些匿名页(如堆内存)换出到 swap——尤其当 vm.swappiness > 0 且内存压力信号(如 pgpgout、pgmajfault 上升)出现时。

在 overcommit 模式下(默认 vm.overcommit_memory = 0),内核允许进程申请远超物理内存+swap 总和的虚拟内存。只要实际没全用上,就不会 OOM;但一旦这些匿名页被真正写入并随后闲置,内核可能优先 swap 出去腾出物理页给更活跃的 page cache 或新分配,导致 swap 使用率持续偏高。

检查是否真存在 overcommit 风险

运行以下命令确认当前 overcommit 策略和使用情况:

慧中标AI标书
慧中标AI标书

慧中标AI标书是一款AI智能辅助写标书工具。

下载
  • cat /proc/sys/vm/overcommit_memory:值为 0(启发式)、1(总是允许)、2(严格限制);生产环境建议用 2 + 合理设 vm.overcommit_ratio
  • grep -i "commit" /proc/meminfo:看 Committed_AS 是否接近或超过 CommitLimit(仅当 overcommit_memory=2 时有意义)
  • cat /proc/sys/vm/swappiness:默认 60,值越高越倾向 swap;对数据库、低延迟服务建议调至 1~10

定位哪些进程在“悄悄”占 swap

free -h 看不到具体谁在用 swap,需结合以下方式:

  • sudo swapon --show=NAME,TYPE,SIZE,USED,PRI:确认 swap 设备状态
  • sudo awk '/Swap:/ {print $3}' /proc/*/status 2>/dev/null | sort -n | tail -10:粗略查看 top 10 占 swap 的进程(单位 KB)
  • sudo smaps_rollup(需 kernel ≥ 4.17)或遍历 /proc/PID/smapsSwap: 行:精确统计每个进程的 swap 使用量
  • sudo cat /sys/fs/cgroup/memory/memory.memsw.usage_in_bytes(若启用 memsw):cgroup 级别总 memory+swap 消耗

实用缓解建议

  • 降低 vm.swappiness 至 10 或更低(sysctl -w vm.swappiness=10),抑制非必要 swap
  • 确认是否真需要 swap:纯计算型服务、内存充足且无休眠需求时,可考虑禁用 swap(swapoff -a),避免干扰内存调度
  • 若必须保留 swap,使用 zram 或 zswap:压缩内存页而非写盘,显著降低 I/O 开销和延迟
  • 检查应用是否存在内存泄漏或缓存滥用(如 JVM -Xmx 过大但实际负载低),导致大量匿名页长期驻留又不活跃
  • 升级内核至 5.0+:引入 vm.reclaim_swappiness(替代 swappiness),更好区分 file-backed 和 anon page 回收倾向

关键点在于:swap 使用率 ≠ 内存瓶颈。重点看 available 是否稳定、pgpgin/pgpgout 是否持续飙升、pgmajfault 是否增长——这些比 swap% 更能反映真实压力。不复杂但容易忽略。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

185

2023.09.27

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

232

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

437

2024.03.01

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

387

2023.09.04

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

392

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

572

2023.08.10

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

352

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2075

2023.08.14

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号