阅读视图

Linux磁盘爆满不用慌

第一步:检查哪个挂载点满了?

df -h

输出示例:

Filesystem      Size  Used Avail Use% Mounted on
/dev/sda1        50G   49G  500M  100% /

一般系统都有多个挂载点,首先找出哪个挂载点爆满。

第二步:哪个目录最占空间?

# 查看
du -h --max-depth=1 / | sort -hr | head -n 10

参数说明:

  • du:查看文件夹体积
  • --max-depth=1:只看一级目录
  • sort:从大到小排序
  • head:只显示前10个

找到哪个目录占用较多,再深入查看:

du -h --max-depth=3 /data | sort -hr | head -n 10

通常 是日志文件占据较大空间,能删除的也只有日志,或者备份,如果实在删不了就只能扩容了。

第三步:找出最大文件

# 从上两步定位出来,再根据大小进一步确认
find /data -type f -size +1G -exec ls -lh {} \; 2>/dev/null | sort -k5 -hr | head -n 20

从上述命令可以看出有个30G的tomcat日志文件,这样就可以清理了,这种大文件建议进行切割,然后定时清理。

第四步:查看被删但仍占空间的文件

 lsof | grep deleted

看到某个被删的日志文件还被占用?

解决办法:重启对应服务即可释放磁盘。

第五步:快速清理技巧

清理项

命令

清空日志文件

> /var/log/xxx.log

  –》这个命令会直接清空该文件的所有内容

删除7天前日志

find /var/log -type f -name "*.log" -mtime +7 -exec rm -f {} \;

清理 Docker

docker system prune -af

清理 APT 缓存

apt clean

清理 YUM 缓存

 yum clean all

【温馨提示】在删除前一定要确保不影响系统运行,删除重要文件前可以做备份或打快照。

总结一句话:

用 df 找哪里满了 → 用 du/find 找大目录/大文件 → 清理/重启释放空间。

如果经常出现,就加一个定时任务定期处理。

  •  

灵感时刻-2025-12-17 14:28:01

这个世界就是没办法可预期或预计,所以就每一步都按照自己期望的事情去做就好了。但多数的情况下每一步都不在计划里,所以这才充满了生活的不确定性和奇妙的。如果说都能按计划去做的话,就没有那么有乐趣的事情,希望大家都能得到自己的自由和期望。

  •  

灵感时刻-2025-10-02 00:10:48

那是我第一次遇到那座山,自然听不得好言相劝,世间多的是空手而归还意兴阑珊,我失去的每一分月亮,都是我的心甘情愿。自此经年,山是山,我是我。

  •  

灵感时刻-2025-09-29 19:12:36

总有一天,我们会知道人心都是一样的。悲伤随处可见,只是在不同的地方,表现形式不同罢了。IMG_0775.jpeg

  •  

Linux下的程序日志查询grep组合拳

正式教学

核心的工具其实还是 grep 命令,下面我将分场景给你讲讲我的实战经验,保证你能直接套用!

场景一:查异常堆栈,不能只看一行!

Java 异常堆栈通常都是多行的,仅仅用 grep "NullPointerException" 只能看到最上面那一行,问题根源在哪你压根找不到。

这时候使用 grep-A (After) 参数来显示匹配行之后的 N 行。

# 查找 NullPointerException,并显示后面 50 行
grep -A 50 "java.lang.NullPointerException" a.log

如果你发现异常太多,屏幕一闪而过,也可以用 less 加上分页查看:

grep -A 50 "java.lang.NullPointerException" a.log | less

less 视图中,你可以:

  • 使用 箭头↑↓Page Up/Down 键来上下滚动

  • 输入 G 直接翻到末尾,方便快速查看最新的日志

  • 输入 /Exception 继续搜索

  • q 键退出

这样你就能 第一时间拿到完整异常上下文信息,告别反复 vi + / 的低效操作!


场景二:实时看新日志怎么打出来的

如果你的应用正在运行,并且你怀疑它会随时抛出异常,你可以实时监控日志文件的增长。

使用 tail -f 结合 grep

# 实时监控 a.log 文件的新增内容,并只显示包含 "java.lang.NullPointerException" 的行及其后50行
tail -f a.log | grep -A 50 "java.lang.NullPointerException"

只要异常一出现,它就会自动打出来,堆栈信息也一并送到你面前!

  • 想停下?Ctrl + C

  • 想更准确?加 -i 忽略大小写,防止大小写拼错找不到


场景三:翻历史日志 or 查压缩日志

服务器上的日志一般都会按天或按大小分割并压缩,变成 .log.2025-07-02.gz 这种格式,查找这些文件的异常信息怎么办?

查找当前目录所有 .log 文件:

# 在当前目录下查找所有以 .log 结尾的文件,-H 参数可以顺便打印出文件名
grep -H -A 50 "java.lang.NullPointerException" *.log

其中 -H 会帮你打印出 是哪个文件 中出现的问题,防止你找完还不知道是哪天的事。

查找 .gz 文件(压缩日志):

zgrep -H -A 50 "java.lang.NullPointerException" *.gz

zgrep 是专门处理 .gzgrep,它的功能和 grep 完全一样,无需手动解压,直接开整!


场景四:统计异常数量(快速判断异常是否频繁)

有时候你需要知道某个异常到底出现了多少次,是偶发还是成灾,使用 grep -c(count):

grep -c "java.lang.NullPointerException" a.log

如果你要统计所有日志里的数量:

grep -c "java.lang.NullPointerException" *.log

其他常用的 grep 参数

参数 作用
-B N 匹配行之前的 N 行(Before)
-A N 匹配行之后的 N 行(After)
-C N 匹配行上下共 N 行(Context)
-i 忽略大小写
-H 显示匹配的文件名
-r 递归搜索目录下所有文件

比如:

grep -C 25 "java.lang.NullPointerException" a.log

这个命令就能让你一眼看到异常前后的上下文,帮助定位代码逻辑是不是哪里先出问题了。

  •