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目录下,方便下载,且重启后通常会自动清理,不占业务磁盘空间。

相关推荐
iCxhust1 小时前
linux目录是否保存在硬盘 启动后读入解析的
linux·运维·服务器
懒鸟一枚1 小时前
Linux 系统 Service 服务配置详解
linux·服务器·网络
RisunJan1 小时前
Linux命令-readonly(Bash 内建设置只读变量)
linux
FlightYe3 小时前
FFmpeg移动端硬解机制
linux·网络·ffmpeg·音视频·实时音视频·视频编解码
笨笨没好名字3 小时前
Leetcode刷题python3版第一周(下)
linux·算法·leetcode
潘正翔3 小时前
docker基础_镜像使用
linux·运维·服务器·docker·容器·centos·devops
24计网1王仔寿4 小时前
Linux运维与云计算全栈系统化学习指南(Shell+虚拟化+OpenStack+Docker+公私云实战)
linux·课程设计·数据库开发·微信公众平台·neo4j·命令模式·sequoiadb
DB哥讲数据库4 小时前
rocky linux安装教程:VMware虚拟机图文讲解部署Rocky Linux 9(附镜像包)
linux·运维·服务器
未*望4 小时前
【Linux入坑(二)—全志T133开发板适配USB-电容屏触摸屏驱动(多点触控) 】
linux·运维·服务器
懒鸟一枚4 小时前
为什么 useradd -rs /bin/false service 创建的用户无法用 su 切换?
linux·服务器·数据库