从云数据库 RDS 回迁单机:我是如何靠 Swap 救回那台快崩掉的 Ubuntu 服务器的

早些年接私活、做企业站,"全家桶"式的云服务(云服务器+云数据库 RDS+对象存储)确实是标配,图的就是个省心。

但这两年形势变了,企业站需求缩减,而且各大云厂商的 RDS 价格越来越硬,对于我们这种追求"极致性价比"的技术人来说,把数据库迁回服务器做单机部署 成了基操。不过,单机部署最大的心病就是:内存不够,数据库直接 OOM(Out of Memory)崩掉。

今天就聊聊这个兜底的"救命稻草"------Swap


什么是 Swap?

简单来说,Swap 就是在你的硬盘上划出一块区域,当系统的物理内存(RAM)不够用时,内核会将一部分暂时不常用的数据挪到这块区域里。

  • 它的作用: 防止系统因为内存耗尽而直接杀死进程(比如 MySQL 进程)。
  • 它的代价: 硬盘的速度(哪怕是 SSD)远慢于内存。所以 Swap 是用来保命的,不是用来当内存扩容用的。

准备工作:检查现状

在操作之前,先看看你的 Ubuntu 22.04/24.04 是否已经开启了 Swap。

bash 复制代码
sudo swapon --show
free -h

或者使用 free -h 查看。如果返回为空,或者 Swap 行显示为 0,说明你还没设置。


实战步骤:五步开启 Swap

假设我们要创建一个 4GB 的 Swap 文件。

1. 创建交换文件

我们直接在根目录下创建一个名为 swapfile 的文件。

bash 复制代码
# 快速分配
sudo fallocate -l 2G /swapfile
# 如果报错直接用下面方式开启:count=4G 也可以,这里用 1024 * 4
sudo dd if=/dev/zero of=/swapfile bs=1M count=4096

2. 设置权限

Swap 文件权限必须极其严格,否则系统会报错。

bash 复制代码
sudo chmod 600 /swapfile

3. 格式化并激活

bash 复制代码
sudo mkswap /swapfile
sudo swapon /swapfile

4. 设置开启自启

bash 复制代码
grep -n "/swapfile" /etc/fstab || echo '/swapfile none swap sw 0 0' | sudo tee -a /etc/fstab

进阶:调优(后续重要!)

开启 Swap 只是第一步,在大厂的生产环境里,我们还会关注两个核心参数。

1. Swappiness(积极度)

swappiness 的值在 0 到 100 之间。

  • 值越高,内核越倾向于把数据往 Swap 挪。
  • 值越低,内核越倾向于压榨物理内存。

对于数据库服务器,我们建议设置成 10(即物理内存剩下 10% 时才开始用 Swap),这样既能保命,又不至于让系统太卡。

bash 复制代码
# 临时修改
sudo sysctl vm.swappiness=10
# 永久修改:在 /etc/sysctl.conf 末尾添加 vm.swappiness=10

2. Cache Pressure(缓存压力)

这个值决定了系统回收用于目录和 inode 对象的频率。对于数据库这种频繁操作文件的场景,建议设置为 50

bash 复制代码
# 临时修改
sudo sysctl vm.vfs_cache_pressure=50
# 永久修改:在 /etc/sysctl.conf 末尾添加 vm.vfs_cache_pressure=50

避坑指南

  1. SSD 是前提: 如果你的云服务器还在用古老的机械硬盘(HDD),开启 Swap 会导致严重的 I/O 等待,甚至让系统彻底假死。现在的 SSD 云盘是标配,可以放心开启。
  2. 监控不可少: Swap 只是"延缓死亡"。如果监控发现 Swap 被占满了,说明你的业务确实该升级内存了,而不是继续加 Swap。
  3. MySQL 的配置: 数据库迁回本地后,记得修改 my.cnf 里的 innodb_buffer_pool_size。一般来说,设置为物理内存的 50%~60% 比较稳妥。
相关推荐
lThE ANDE5 小时前
最完整版Linux安装Redis(保姆教程)
linux·运维·redis
yyuuuzz8 小时前
企业出海:技术部署与运维避坑
运维
郝亚军9 小时前
ubuntu通过samba,让win11可以访问其共享文件夹
linux·服务器·ubuntu
workflower9 小时前
人机交互部分OOD
运维·人工智能·自动化·集成测试·人机交互·软件需求
一个人旅程~9 小时前
旧电脑的“拯救者”?Linux Mint20.3是怎样适配软件硬件以及兼顾兼容与性能的平衡的?
linux·经验分享·电脑
农村小镇哥9 小时前
nginx服务器的介绍
运维·服务器·nginx
小夏子_riotous9 小时前
Docker学习路径——3、常用命令
linux·运维·服务器·学习·docker·容器·centos
其实防守也摸鱼10 小时前
无线网络安全---WLAN相关安全工具--kali(理论附题目)
linux·安全·web安全·学习笔记·kali·命令模式·wlan
uesowys11 小时前
CentOS Linux安装部署OpenClaw
linux·centos·安装部署openclaw
IMPYLH12 小时前
Linux 的 rm 命令
linux·运维·服务器·网络·bash