0

0

Linux如何一键清理系统缓存和无用包?(空间释放)

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-03-12 19:35:52

|

115人浏览过

|

来源于php中文网

原创

Linux磁盘空间告急时,可依次执行APT缓存清理、孤立包与残留配置清除、旧内核安全卸载、内存缓存释放,并通过整合脚本一键自动化完成全部操作。

linux如何一键清理系统缓存和无用包?(空间释放)

如果您发现Linux系统磁盘空间持续告急,且确认并非由用户数据或日志暴增引起,则很可能是APT缓存、旧内核镜像、孤立依赖包及内存缓存长期累积所致。以下是实现空间释放的一键式清理方法:

一、清理APT包管理器缓存

APT在安装或升级软件时会将.deb安装包保留在/var/cache/apt/archives目录中,这些文件安装完成后即失去作用,但默认不会自动删除,可占用数GB空间。清理操作安全可逆,不影响已安装软件功能。

1、查看当前APT缓存占用大小:sudo du -sh /var/cache/apt/archives

2、仅清除已无法下载的旧版本安装包(保留当前可用版本):sudo apt autoclean

3、彻底清空全部.deb缓存(包括当前版本,重装时需重新下载):sudo apt clean

二、移除孤立依赖与残留配置包

卸载软件后,APT默认保留其依赖库;当多个软件共用同一依赖时,该依赖不会被自动删除,久而久之形成“孤儿包”。这些包不再被任何已安装程序调用,属于安全可删冗余项。同时,已卸载但未清除配置的软件会以rc状态滞留在dpkg数据库中,占用磁盘且干扰包管理。

1、预览将被移除的孤立软件包列表(不执行实际删除):sudo apt autoremove --dry-run

2、执行清理,仅删除二进制文件和共享库:sudo apt autoremove

3、连同残留配置文件一并彻底清除:sudo apt autoremove --purge

4、强制清除所有标记为rc(removed but config remains)状态的包:dpkg -l | grep '^rc' | awk '{print $2}' | sudo xargs dpkg -P

三、安全删除多余内核镜像与头文件

/boot分区空间有限,每次内核升级都会新增linux-image-*、linux-headers-*等文件。旧版本若未手动清理,极易填满/boot导致无法更新或启动失败。必须先确认当前运行内核,再针对性删除非活跃版本,避免误删导致系统无法启动。

1、查看当前正在使用的内核版本:uname -r

2、列出所有已安装的内核相关包(含image、headers、modules):dpkg --get-selections | grep 'linux-image\|linux-headers'

腾讯交互翻译
腾讯交互翻译

腾讯AI Lab发布的一款AI辅助翻译产品

下载

3、从上一步结果中识别出版本号低于当前内核且非最新升级版的条目(例如当前为6.8.0-52-generic,则可安全删除6.5.0-44-generic等)

四、释放内存页缓存、dentries与inodes

Linux为提升I/O性能,会将频繁访问的文件内容、目录结构(dentries)和inode信息缓存在内存中(即buff/cache)。这部分内存虽属“可用”,但在内存紧张时需主动释放。操作前必须同步磁盘,防止未写入数据丢失。

1、强制将缓冲区数据写入磁盘:sync; sync; sync

2、清空页面缓存:echo 1 | sudo tee /proc/sys/vm/drop_caches

3、清空dentries和inodes缓存:echo 2 | sudo tee /proc/sys/vm/drop_caches

4、同时清空页面缓存、dentries和inodes:echo 3 | sudo tee /proc/sys/vm/drop_caches

五、自动化整合脚本(一键执行)

将上述关键步骤整合为可重复调用的shell脚本,避免逐条输入命令出错,并确保操作顺序符合安全逻辑:先同步磁盘、再清理缓存、最后处理包与内核。

1、创建脚本文件:sudo nano /usr/local/bin/clean-linux-system

2、写入以下内容:

#!/bin/bash\nsync\necho 3 | sudo tee /proc/sys/vm/drop_caches\nsudo apt autoclean\nsudo apt clean\nsudo apt autoremove --purge\ndpkg -l | grep '^rc' | awk '{print $2}' | sudo xargs -r dpkg -P\n# 自动识别并保留当前及最新内核,仅删除其余旧内核\nCURRENT_KERNEL=$(uname -r | sed 's/-generic//')\nOLD_KERNELS=$(dpkg --get-selections | grep 'linux-image\|linux-headers' | grep -v "$CURRENT_KERNEL" | grep -v 'linux-image-$(uname -r)' | awk '{print $1}' | sort -V | head -n -1)\n[ -n "$OLD_KERNELS" ] && sudo apt purge $OLD_KERNELS

3、赋予执行权限:sudo chmod +x /usr/local/bin/clean-linux-system

4、立即运行:sudo clean-linux-system

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

192

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

19

2026.02.03

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

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

409

2023.09.04

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

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

385

2023.06.29

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

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

2111

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

357

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

259

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

329

2023.10.09

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

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

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