先清理后扩容是解决CentOS磁盘空间不足的核心策略。首先通过df -h和du -sh配合sort -rh逐层定位大文件,重点清理/var/log日志、/var/cache/yum缓存、旧内核及/tmp临时文件,可使用yum clean all和package-cleanup命令快速释放空间;若需长期扩容,则推荐LVM方式,通过pvcreate、vgextend、lvextend扩展逻辑卷并用xfs_growfs或resize2fs调整文件系统,实现在线扩容;对于非LVM环境,可新增磁盘并分区格式化后挂载至指定目录,同时配置/etc/fstab确保持久化;此外,应建立磁盘监控告警、实施日志轮转与集中管理、定期归档冷数据、合理规划分区及配额,以实现磁盘使用的主动管理与性能优化。

当你的CentOS服务器突然报告磁盘空间不足,或者通过
df -h
处理CentOS磁盘满的问题,通常是清理和扩容双管齐下。
首先,快速定位并清除不必要的占用。这包括检查日志文件、YUM缓存、旧的内核版本、临时文件,以及用户目录中可能存在的巨大归档或误操作生成的文件。很多时候,仅仅是清理这些“垃圾”就能争取到宝贵的喘息空间。我会用
df -h
du -sh *
sort -rh
如果清理只是治标不治本,或者你的应用数据确实在不断增长,那么扩容就是必然的选择。对于使用了LVM(逻辑卷管理)的系统,扩容相对优雅,可以在线进行,不中断服务。这涉及到添加新的物理磁盘或分区,将其加入到现有的卷组中,再扩展逻辑卷,最后扩展文件系统。如果系统没有使用LVM,或者需要挂载一块全新的数据盘,那就需要分区、格式化并挂载,然后修改
/etc/fstab
磁盘空间告急时,最要紧的是找出那些“吃掉”空间的家伙。我个人的经验是,这就像一场侦探游戏,需要一点点线索去追踪。
一开始,我会用
df -h
/
接下来,就是深入挖掘了。我通常会切换到根目录
/
du -sh *
/var
cd /var
du -sh *
几个常见的“藏污纳垢”之地:
/var/log
find /var/log -type f -size +100M -print0 | xargs -0 du -h | sort -rh
rm
cat /dev/null > filename
logrotate
/var/cache/yum
yum clean all
/boot
package-cleanup --oldkernels --count=1
yum-utils
/tmp
rm -rf /tmp/*
docker system prune
/home
du -sh /home/*
清理时,我习惯先用
du -sh
rm
ncdu
当清理已无法满足需求,或者你预见到未来数据增长的趋势,扩容就成了必然。在CentOS上,这主要有两种主流做法:LVM扩容和直接挂载新磁盘。
LVM扩容 (推荐,尤其是在线扩容)
LVM(Logical Volume Manager)是Linux上一个非常强大的磁盘管理工具,它允许你将多个物理磁盘或分区组合成一个存储池,然后从这个池中创建逻辑卷。它的好处是,你可以在不停机的情况下扩展文件系统。
假设你的根目录
/
centos_root
/dev/sdb
准备新的物理卷 (PV): 如果你新加了一块硬盘
/dev/sdb
pvcreate /dev/sdb
如果只是现有硬盘上的一个分区,比如
/dev/sda3
扩展卷组 (VG): 将新的物理卷添加到你的卷组中。通常,CentOS默认的卷组名是
centos
vg_centos
vgdisplay
vgextend centos /dev/sdb # 假设你的卷组名是 centos
扩展逻辑卷 (LV): 现在,你的卷组有了更多的可用空间。你可以将这些空间分配给你的逻辑卷。
lvextend -L +50G /dev/mapper/centos-root # 增加50GB到根逻辑卷
或者,如果你想把所有可用空间都分配给它:
lvextend -l +100%FREE /dev/mapper/centos-root
这里的
/dev/mapper/centos-root
lvdisplay
扩展文件系统: 这是最后一步,也是最关键的一步,它让操作系统感知到文件系统变大了。 如果你的文件系统是XFS(CentOS 7/8默认):
xfs_growfs / # 扩展根文件系统
如果你的文件系统是Ext4:
resize2fs /dev/mapper/centos-root # 扩展根文件系统
完成这些步骤后,你再用
df -h
直接挂载新磁盘
如果你不使用LVM,或者只是想为某个特定应用(比如数据库数据、网站文件)提供额外的存储空间,那么直接添加并挂载新磁盘是更简单的选择。
识别新磁盘: 插入新硬盘后,用
fdisk -l
lsblk
/dev/sdb
/dev/sdc
分区: 使用
fdisk /dev/sdb
gdisk
格式化: 将新创建的分区格式化为所需的文件系统,例如XFS或Ext4。
mkfs.xfs /dev/sdb1 # 格式化为XFS # 或者 mkfs.ext4 /dev/sdb1 # 格式化为Ext4
创建挂载点并挂载: 创建一个目录作为挂载点,然后将分区挂载到该目录。
mkdir /data_new mount /dev/sdb1 /data_new
配置/etc/fstab
/etc/fstab
blkid /dev/sdb1
/etc/fstab
UUID=xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx /data_new xfs defaults 0 0
保存后,可以运行
mount -a
仅仅是应急清理和被动扩容,长远来看并不是最佳实践。更高级别的策略,在于预防和优化,让磁盘管理变得更主动、更智能。
建立磁盘使用监控和告警机制: 这是最基础也是最重要的。通过Prometheus、Grafana、Zabbix或者简单的shell脚本,定期检查磁盘使用率。设置阈值,比如当某个分区达到80%时发送警告,90%时发送严重警告。这样你就能在磁盘爆满前得到通知,有充足的时间去处理,而不是等到服务崩溃了才发现。我个人喜欢用Prometheus,它收集数据灵活,Grafana的可视化也做得很好。
实施完善的日志管理策略: 日志是磁盘空间的“隐形杀手”。除了
logrotate
定期审查和归档不常用数据: 很多时候,磁盘上会堆积大量不再活跃但又舍不得删的数据,比如旧的备份、过期的项目文件、测试数据等。建立一个定期的数据审查流程,比如每月或每季度一次,找出这些“冷数据”。对于这些数据,可以考虑将其归档到更便宜、容量更大的存储介质(如NAS、S3兼容对象存储)上,或者压缩存储。
合理规划文件系统和分区: 在系统安装之初,就应该根据服务器的用途,合理规划分区和文件系统。例如,将
/var
/var/log
/var/lib/mysql
/var/lib/pgsql
启用用户和组磁盘配额: 如果服务器是多用户环境,或者有多个应用共享存储,为用户或组设置磁盘配额(Quota)可以有效限制他们对磁盘空间的使用,防止某个用户或应用无限制地占用资源。
利用文件系统特性: 例如,对于一些不常访问但又不能删除的文件,可以考虑使用文件系统级别的压缩(如ZFS或Btrfs的透明压缩功能,或者对单个文件使用
gzip
说实话,每次磁盘满了才想到去清理或扩容,这本身就是一种被动的应对。真正的高手,往往在问题发生之前,就已经通过周密的规划、严谨的监控和自动化的管理,将这些潜在的风险降到了最低。毕竟,谁也不想在半夜被磁盘告警吵醒,然后手忙脚乱地去“救火”吧。
以上就是CentOS磁盘满了怎么处理_CentOS磁盘空间清理与扩容教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号