Linux下快速提取指定时间段日志的三种方法

 更新时间:2025年12月10日 08:27:22   作者:天天进步2015  
这篇文章主要为大家详细介绍了Linux下快速提取指定时间段日志的三种方法,本文重点比较了这三种方案的优缺点,感兴趣的小伙伴可以跟随小编一起学习一下

前言

做后端开发或运维的同学,一定都经历过这样的场景:

线上服务出了 Bug,老板让你查一下今天上午 10:00 到 11:00 到底发生了什么。你登录服务器一看,app.log 已经跑到了 10GB

这时候如果你直接 vim 打开,服务器可能会卡死;如果你用 cattail 慢慢翻,眼睛都要看瞎。

其实,在 CentOS(以及绝大多数 Linux 发行版)下,我们完全不需要写复杂的脚本,只需要一行命令,就能把指定时间段的日志另存为一个新的文件。

今天就分享三种最常用的姿势,由浅入深,总有一款适合你。

准备工作

假设我们的日志文件名为 app.log,格式如下(标准的日期开头):

2023-10-27 10:00:01 [INFO] User login success
2023-10-27 10:00:05 [WARN] Database query slow
...

我们的目标是:将 10:00 到 11:00 的日志,另存为 bug_report.log

姿势一:sed —— 简单粗暴(推荐日志连续的情况)

sed 是流编辑器,它非常适合处理这种“从 A 开始,到 B 结束”的任务。

命令模板:

sed -n '/开始时间/,/结束时间/p' 原日志 > 新日志

实战操作:

sed -n '/2023-10-27 10:00:00/,/2023-10-27 11:00:00/p' app.log > bug_report.log

优点:

  • 命令简单,好记。
  • 处理速度极快。

缺点(非常重要):

sed 是完全匹配字符串。如果你的日志里正好没有 10:00:00 这一秒的记录(比如那一秒没人访问),sed 就会找不到开始标记,导致截取失败。

姿势二:awk —— 精准打击(最稳健的方案)

如果你担心日志中间有断档(比如某一秒没有日志),awk 是最佳选择。它不看字符串是否相等,而是把时间当做字符进行比较(大于/小于)

只要日志行首是时间,它就能精确捕捉范围。

命令模板:

awk '$0 >= "开始时间" && $0 <= "结束时间"' 原日志 > 新日志

(注:$0 代表整行内容,如果只需要比较第2列时间,可以用 $2)

实战操作:

awk '$0 >= "2023-10-27 10:00:00" && $0 <= "2023-10-27 11:00:00"' app.log > bug_report.log

优点:

  • 容错率高:即使日志里没有 10:00:00 这一行,它也会从 10:00:01 开始截取。
  • 逻辑清晰,支持复杂的过滤条件。

姿势三:grep —— 模糊搜索(适合“按小时”抓取)

如果你不需要精确到秒,只是想把“10 点这一小时”的所有日志都拉出来看看,grep 是最快的。

命令模板:

grep "^时间前缀" 原日志 > 新日志

实战操作(抓取 10 点段所有日志):

grep "^2023-10-27 10:" app.log > 10_am_logs.log

优点:

  • 几乎没有心智负担,最常用的命令。
  • 适合快速排查故障范围。

总结与建议

方案命令关键字适用场景稳健性
方案一sed确定起始时间点一定存在时⭐⭐⭐
方案二awk生产环境首选,时间点可能不连续⭐⭐⭐⭐⭐
方案三grep只需要按小时/按分钟模糊查询⭐⭐⭐⭐

建议:

如果你在写自动化脚本来备份日志,请务必使用 方案二 (awk),因为它不会因为某一秒日志的缺失而导致脚本失效。

到此这篇关于Linux下快速提取指定时间段日志的三种方法的文章就介绍到这了,更多相关Linux提取指定时间段日志内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • centos下搭建SVN服务器和MySQL

    centos下搭建SVN服务器和MySQL

    这篇文章主要为大家详细介绍了centos下搭建SVN服务器和MySQL的相关教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Linux环境下python2.7.6升级python3.5.2

    Linux环境下python2.7.6升级python3.5.2

    本篇文章主要介绍了centos7下python2.7.5升级到3.5.2,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • Linux下Apache安装/增加mod_rewrite模块的方法

    Linux下Apache安装/增加mod_rewrite模块的方法

    如果你的apache已经安装好了,现在只想编译出mod_rewrite.so模块,在apache中进行加载,下面我们就介绍这个方法。
    2011-04-04
  • Linux系统的SSL/TLS证书机制详解

    Linux系统的SSL/TLS证书机制详解

    文章概述了SSL/TLS证书原理、Linux系统预装证书的存储与用途,以及新服务(如POP3)自动生成自签名证书的过程和局限性,最后推荐使用Let's Encrypt等自动化工具提升安全性
    2025-09-09
  • Linux basename命令的使用方法

    Linux basename命令的使用方法

    这篇文章主要介绍了Linux basename命令的使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-02-02
  • Linux下如何搭建两个tomcat服务

    Linux下如何搭建两个tomcat服务

    本篇文章主要介绍了Linux下如何搭建两个tomcat服务,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • linux手工配置ip地址详细步骤

    linux手工配置ip地址详细步骤

    大家好,本篇文章主要讲的是linux手工配置ip地址详细步骤,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • 详解centos7使用无线wifi连接的方法

    详解centos7使用无线wifi连接的方法

    本篇文章主要介绍了centos7使用无线wifi连接的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2016-12-12
  • 在 Ubuntu 15.04/CentOS 7 中安装 Lighttpd Web 服务器的方法

    在 Ubuntu 15.04/CentOS 7 中安装 Lighttp

    以下是我们在运行 Ubuntu 15.04 或 CentOS 7 Linux 发行版的机器上安装 Lighttpd Web 服务器的简要流程,需要的朋友可以参考下
    2017-04-04
  • centos 6.7 下安装 redis-3.2.5的步骤

    centos 6.7 下安装 redis-3.2.5的步骤

    这篇文章主要介绍了centos 6.7 下安装 redis-3.2.5的步骤,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06

最新评论