Linux上 log日志很大,如何获取部分内容?

lumen.log日志非常大时,直接打开或传输会消耗大量 I/O 和 CPU 资源,影响服务器性能。以下是几种对服务器影响最小的获取部分内容的方法:

1. 查看最后 N 行(最常用,查看最新报错)

如果你只是想看最新的报错信息,不要打开整个文件,使用 tail

  • 查看最后 100 行:

    复制代码
    tail -n 100 lumen.log
  • 实时监控最新日志(类似 tail -f):

    复制代码
    tail -f lumen.log

2. 提取指定时间段的日志(精准获取)

如果错误发生在特定时间(比如你之前提到的 08:09:27),可以用 sedgrep截取那一段时间的日志,而不是加载整个文件。

  • 提取 08:09:00 到 08:10:00 之间的日志:

    复制代码
    sed -n '/2026-02-26 08:09:/,/2026-02-26 08:10:/p' lumen.log > /tmp/part.log

    解释:只把匹配到的内容写入 /tmp/part.log,这样不会占用太多内存。

  • 使用 grep过滤特定关键词(如你之前的报错):

    复制代码
    grep "queryOrderHelper" lumen.log > /tmp/error_part.log

3. 分割大文件(如果必须下载)

如果日志实在太大,且你需要保留格式下载到本地分析,可以使用 split命令将其切成小文件。

  • 每 50MB 切分一个文件:

    复制代码
    split -b 50M lumen.log part_

    这会在当前目录生成 part_aa, part_ab等小文件,你可以只下载其中一个。

如:

4. 打包压缩(减少传输量)

在传输前先压缩,能显著减少 I/O 读写和网络传输时间。

  • 仅打包今天的日志并压缩:

    复制代码
    # 假设今天是2026-02-26
    grep "2026-02-26" lumen.log | gzip > /tmp/today.log.gz

💡 性能优化建议 (Performance Tips)

  1. 避免用 vimcat打开大文件:这会一次性加载文件到内存,可能导致服务器卡顿甚至 OOM(内存溢出)。

  2. 使用管道 | :像上面的 sedgrep命令,通过管道处理,通常是流式读取,对内存占用极小。

  3. 输出到 /tmp :处理完的文件放在 /tmp目录下,方便下载,且重启后通常会自动清理,不占业务磁盘空间。

相关推荐
zhangrelay1 小时前
云课实践速通系列-基础篇汇总-必修-通识基础和专业基础-2026--工科--自动化、电气、机器人、测控等
linux·笔记·单片机·学习·ubuntu·机器人·自动化
陶然同学2 小时前
【Linux及Shell】VMware&Ubuntu&Xshell安装
linux·运维·xshell8·xftp8
咖喱o3 小时前
DHCP
linux·运维·服务器·网络
IMPYLH3 小时前
Linux 的 touch 命令
linux·运维·服务器·bash
lzh200409193 小时前
深入学习Linux进程间通信:共享内存
linux·c++
ErizJ3 小时前
Linux|学习笔记
linux·笔记·学习
wangchunting3 小时前
VMware17 使用Rocky Linux 9.7系统
linux·运维·服务器
相醉为友3 小时前
040 Linux/裸机/RTOS 项目开发的跨平台兼容性——C语言静态接口抽象底层原理分析
linux·c语言·mcu
Mapleay4 小时前
ALSA 专业术语 和 dai_link 分析
linux