Swap分区是Linux系统中当物理内存不足时,系统会将部分内存数据转移到磁盘上的虚拟内存区域,用来临时缓解内存压力。很多使用宝塔面板的用户会发现Swap分区占用率持续升高,导致服务器响应变慢、磁盘IO负载上升,这种情况大多和系统的Swappiness参数设置有关。

Swap分区占用过高的常见原因
除了服务器本身物理内存不足之外,Swappiness参数设置不合理是最主要的原因。这个参数的取值范围是0到100,数值越大代表系统越倾向于优先使用Swap分区,而不是释放内存中的缓存数据。
- 默认Swappiness参数通常设置为60,对于内存较小的服务器来说,这个数值偏高,很容易触发Swap使用
- 服务器上运行了内存占用高的服务,比如MySQL、Java应用,物理内存被大量占用后触发Swap调度
- 系统缓存回收机制被干扰,导致内存中的可回收缓存没有被及时释放,转而使用Swap分区
Swappiness参数的作用逻辑
Swappiness参数本质是控制内核回收内存时的策略倾向:
- 当参数设为0时,内核会尽量避免在内存还有可用空间时使用Swap,除非内存完全耗尽
- 当参数设为100时,内核会非常激进地使用Swap分区,哪怕物理内存还有剩余
- 对于大多数运行Web服务的服务器,建议将参数设置在10到30之间,平衡内存使用和Swap依赖
在宝塔面板中调整Swappiness参数的步骤
第一步:查看当前Swappiness参数值
可以通过终端命令先查看当前的参数设置,确认是否需要调整:
# 查看当前Swappiness值 cat /proc/sys/vm/swappiness
第二步:临时调整参数(立即生效,重启后失效)
如果只是临时测试调整效果,可以直接执行以下命令,将参数设为10:
# 临时设置Swappiness为10 sysctl vm.swappiness=10
第三步:永久调整参数(重启后保持生效)
临时调整的参数在服务器重启后会恢复默认值,需要修改系统配置文件实现永久生效:
# 编辑sysctl配置文件 vi /etc/sysctl.conf # 在文件末尾添加以下内容,如果已有vm.swappiness配置则修改数值 vm.swappiness=10 # 保存退出后执行以下命令让配置生效 sysctl -p
第四步:验证调整结果
调整完成后可以再次查看参数值,确认设置已经生效:
# 再次查看Swappiness值 cat /proc/sys/vm/swappiness
调整后的效果验证与注意事项
调整完成后可以观察服务器的内存和Swap使用情况,通常Swap占用会逐步下降,磁盘IO压力也会有所缓解。需要注意以下几点:
- 不要将Swappiness设置为0,除非服务器物理内存非常充足,否则可能导致内存耗尽时服务直接崩溃
- 如果调整后发现系统出现内存不足的错误,可以适当调高参数值,比如设置为20
- 如果服务器物理内存本来就很小(比如小于2G),调整参数只能缓解问题,最好还是升级物理内存
其他优化Swap占用的补充方案
除了调整Swappiness参数之外,还可以配合以下操作进一步降低Swap依赖:
- 在宝塔面板中优化MySQL等服务的配置,降低内存占用上限
- 关闭服务器上不必要的服务,减少内存消耗
- 如果Swap分区本身创建得过大,可以适当缩小Swap分区的大小,避免系统过度使用
注意:调整系统内核参数前建议先备份重要数据,避免操作失误导致系统异常。如果是生产环境的服务器,建议先在测试环境验证调整效果后再操作。
Swap分区Swappiness参数宝塔面板磁盘依赖修改时间:2026-07-01 07:12:30