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
    • 最新
    • 标签
主页 / unix / 问题 / 562611
Accepted
mike rodent
mike rodent
Asked: 2020-01-18 04:27:51 +0800 CST2020-01-18 04:27:51 +0800 CST 2020-01-18 04:27:51 +0800 CST

logrotate 是如何工作的?

  • 772

我真的很难理解logrotate在我自己的 shell 文件中运行命令时是如何工作的,以及它是如何不工作的。

有问题的命令是:

rclone -L -vv --log-file "/home/mike/tmp/qqq.log"  sync "/media/mike/W10 D drive/My Documents/"  remote:MyDocuments_M17A_from_Linux

我想要什么:

我希望经常检查这个 qqq.log 文件,比如每 10 分钟一次,看看它是否超过了给定的大小,比如 1 MB。如果有,旋转文件。rclone使用该-vv选项会故意产生丰富的输出(即试图理解让 logrotate 为这个用例工作)。

这里有一个适度有用的教程,但它仍然让我一无所知:

  1. 您打算如何配置来自您自己的非系统进程的日志轮换?您是要在底部粘贴线条/etc/logrotate.conf吗?这就是我所做的(在“#system-specific logs may be configured here”下):

    /home/mike/tmp/qqq.log {
      notifempty
      size 1M
      daily
      create 0664 root root
      rotate 3
    }
    

    后来:我现在意识到您也可以将单个文件放入/etc/logrotate.d其中-那里没有太大的复杂性。

  2. 是不是默认情况下logrotate每天只运行一次,凭借文件/etc/cron.daily/logrotate?

  3. 这是否意味着如果我想要更频繁的检查,我可能应该设置一个cron工作来执行此操作,每 10 分钟运行一次(在此示例中)?

  4. 你打算以logrotate <config file>root身份运行吗?我问这个问题是因为我以 root 和用户身份都尝试过。用户似乎没有工作。

指向此类设置的初学者指南的链接(这种设置并不少见)会很有帮助。我已经搜索过,但我发现的大部分内容都没有为您提供分步指南。

logs logrotate
  • 2 2 个回答
  • 4896 Views

2 个回答

  • Voted
  1. Best Answer
    roaima
    2020-01-18T05:20:44+08:002020-01-18T05:20:44+08:00

    logrotate可以作为普通用户运行,无需管理权限,为该用户轮换日志。

    # Create a local per-user configuration file
    cat >.logrotate.conf <<'X'
    /home/mike/tmp/qqq.log {
        notifempty
        missingok
        size 1M
        rotate 3
    }
    X
    
    # Run logrotate with that configuration file
    /usr/sbin/logrotate -v -s .logrotate.state .logrotate.conf
    

    我删除了您的daily标准,因为您想要纯粹基于大小的检查,这会将任何可能的操作限制为每天一次(每天第一次logrotate运行,因为它发生了)。我已替换create为,missingok以便由您的实际rclone工作来创建输出文件而不是logrotate.

    然后将logrotate命令放入您的用户crontab文件中:

    # Capture any existing crontab entries
    crontab -l >.crontab
    
    # Append ours to the list
    echo '0 * * * * /usr/sbin/logrotate -s .logrotate.state .logrotate.conf >>.crontab.log 2>&1' >>.crontab
    
    # Reload crontab
    crontab .crontab
    

    使用此示例,命令的输出将被写入.crontab.log,您可能需要一个logrotate条目以每月循环或重置它。

    • 9
  2. X Tian
    2020-01-18T05:19:04+08:002020-01-18T05:19:04+08:00

    当您生成自己的日志文件并需要更实时的大小切割时,您应该在此处查看 Apache 实用程序rotatelogs 。

    它通过读取标准输入来工作,并根据命令行参数分割日志文件。

    例如。

    program-writing-to-stdout|/bin/rotatelogs /home/mike/tmp/qqq.log 1M"
    

    另一方面, logrotate在运行时检查日志文件,通常系统设置为每天运行一次 logrotate(通过 cron)。子系统的配置通常通过将配置文件放入其中来完成/etc/logrotate.d,是的,它通常以 root 身份运行。

    编辑:@mike rodent

    logrotate 运行(通过 cron 或手动),然后检查在文件系统中看到的日志文件统计信息,然后根据其配置触发轮换。

    rotatelogs读取它的标准输入连续追加到日志文件,然后当日志文件的时间或大小达到触发点时,它关闭当前日志文件,创建一个新的日志文件(适当命名),然后继续追加到新的日志文件。

    这与您如何启动生成输出的程序有关,它需要写入标准输出,然后将其通过管道传输到旋转日志中。

    例如

    while true ; do date ; sleep 30 ; done | rotatelogs -n 10 /home/mike/tmp/qqq.log 60
    

    会给你一个循环旋转 10 个文件,每 60 秒切割一次

    使用rclone,我希望--log-file "/dev/stdout"它会写入标准输出。

    [编辑 2] @mike rodent

    我不熟悉 rclone,它是否写入 stdout 或 stderr 以及它写入的任何内容,但有一些方法可以解决这个问题,即使它--log-file=/dev/stdout不起作用。

    这个StackOverflow Q/Answer等解释了重定向和管道。但总而言之,可以仅重定向 stderr 或与 stdout 合并到管道中。

    重击示例:

    将标准错误与标准输出合并到管道中

    FirstCommand 2>&1 | OtherCommand
    

    只有标准错误进入管道,标准输出到其他文件(可能是 /dev/null 甚至只是一个-关闭标准输出的连字符)。

    FirstCommand 2>&1 1>otherfile.log | otherCommand
    

    这些示例使用较旧的 bash 语法,bash v4 有一个现代的不那么冗长的变体。

    • 4

相关问题

  • 使用 sed 清理日志文件中的长路径

  • logrotate 描述符可以处理多个通配符吗?

  • systemd:如何将标准输出重定向到日志文件

  • journalctl 中的区分级别

  • 为什么 logrotate 不自动旋转?

Sidebar

Stats

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

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve