AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 42527
Accepted
Aleksandar Ivanisevic
Aleksandar Ivanisevic
Asked: 2009-07-19 07:46:10 +0800 CST2009-07-19 07:46:10 +0800 CST 2009-07-19 07:46:10 +0800 CST

日志轮换工具,仅保留指定数量的日志并丢弃其他所有内容

  • 772

我正在寻找一个类似 cronolog 的工具,它只保留最后 n 行或最后 x 分钟的日志,并丢弃其他所有内容

有这样的野兽吗?

更新:

我知道 logrotate 并且它重命名和压缩旧的日志文件,这不是我想要的。

我想丢弃旧的日志行,只保留最近的行。

就像经常这样做:tail -10000 logfile > logfile.new mv logfile.new logfile 除了使用这种技术您肯定会丢失日志行并且您必须重新启动或以其他方式向日志应用程序发出信号以重新打开日志文件。

logging apache-2.2 log-files syslog
  • 5 5 个回答
  • 1344 Views

5 个回答

  • Voted
  1. Best Answer
    Jeremy Bouse
    2009-07-21T04:43:16+08:002009-07-21T04:43:16+08:00

    可以使 Logrotate 只保留一个日志文件的副本...如果您使用 RTFM,您会发现以下有关配置设置的信息:

    rotate count
        Log files are rotated count times before being removed or mailed to the 
        address specified in a mail directive. If count is  0,  old  versions  
        are  removed  rather than rotated.
    

    您可以再次从logrotate(8)手册页中将rotate与size结合起来,以保持文件较小。虽然不是按行数,而是按 k、M、G 大小。

    size size
        Log  files  are rotated when they grow bigger than size bytes. If size is 
        followed by M, the size if assumed to be in megabytes.  If the G suffix is 
        used, the size  is  in gigabytes.   If  the k is used, the size is in 
        kilobytes. So size 100, size 100k, and size 100M are all valid.
    
    • 4
  2. Saurabh Barjatiya
    2009-07-19T09:42:16+08:002009-07-19T09:42:16+08:00

    您可以使用logrotate并放置

    tail -10000 logfile.0 > logfile.0.new 
    mv logfile.0.new > logfile.0
    

    作为 postrotate 命令的一部分。logrotate允许您指定 postrotate 命令。

    • 2
  3. Bernhard
    2009-07-19T13:07:16+08:002009-07-19T13:07:16+08:00

    无论如何,您都必须重新启动应用程序或发出信号。应用程序必须以某种方式了解 seek()ing 的新偏移量,或者在修剪日志文件时必须重新打开文件句柄。

    • 1
  4. Kevin M
    2009-07-19T08:00:23+08:002009-07-19T08:00:23+08:00

    不完全是你在说什么,但你可以看看logrotate(8)。从手册页:

    logrotate 旨在简化生成大量日志文件的系统的管理。它允许日志文件的自动轮换、压缩、删除和邮寄。每个日志文件都可能被处理......当它变得太大时。

    它默认安装在 RHEL 和衍生产品上。我不知道其他任何东西,比如 Ubuntu/derivitives 或 Windows。

    • 0
  5. Aleksandar Ivanisevic
    2009-07-21T03:58:24+08:002009-07-21T03:58:24+08:00

    最后我解决了这个问题(不是最优雅的,但它有效):

    在 apache (或任何记录的人)中:

    CustomLog "|/usr/local/cronolog/sbin/cronolog /var/tmp/mylog.%Y%m%d.log" logformat

    在 cron.daily 中:

    find /var/tmp/ -name mylog* -mtime +$days | xargs --no-run-if-empty rm

    这将删除旧日志

    最后在分析脚本中:

    lastdate=$(date -d "$INTERVAL 秒前" +%Y-%m-%dT%H:%M:%S)

    grep -h $SEARCH /var/tmp/mylog* | awk -v lastdate="$lastdate" '$1>lastdate { print }' > /tmp/cutlog

    然后使用 /tmp/cutlog

    上面的示例假定第一个字段中的 ISO 时间戳,例如:2009-07-20T13:52:32

    不是最优雅的方式,但它可以满足我的要求。也许有一天我会为 cronolog 写一个功能,它会做同样的事情:)

    • 0

相关问题

  • 在您分发的应用程序中使用 Apache HTTPD 运行 SSL 的最佳方式是什么?

  • 阿帕奇的替代品

  • 如何强制我的网址始终以 www 开头?

  • 在 Linux Xen VPS 上优化 Apache 和 MySQL

  • mod_rewrite 不转发 GET 参数

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve