当前位置: 首页 > article >正文

如何在 Ubuntu 22.04 上配置 Logrotate 高级教程

简介

本教程将教你如何在 Ubuntu 22.04 上进行 Logrotate 的高级配置。

日志管理对于维护系统性能和确保你的日志不会占用太多磁盘空间至关重要。在 Ubuntu 上,logrotate 是一个强大的工具,它可以通过轮转、压缩和删除旧日志来自动管理日志文件。在本教程中,我们将介绍在 Ubuntu 系统上配置 logrotate 以实现高效日志管理的步骤。

对于那些需要对日志轮转进行更精细控制的人来说,Logrotate 提供了高级配置选项。这些选项对于管理大规模环境、确保最佳性能和处理特定的应用程序需求尤其有用。下面,我们将深入研究 Logrotate 的一些高级功能和配置。

准备工作

服务器准备

必要前提:

  • 一个充满求知欲的大脑。
  • 一台 Linux 服务器(推荐腾讯云、阿里云或雨云等)。

我将以 雨云 为例,带大家创建一台自己的云服务器,以便学习本篇文章的内容。

注册链接: https://rainyun.ivwv.site

创建雨云服务器

以下步骤仅供参考,请根据实际需求选择配置。

  • 点击 云产品云服务器立即购买
  • 选择距离你较近的区域,以保证低延迟。

  • 按照自己需求选择配置,选择Ubuntu 22.04 版本,按照自己需求是否预装Docker。
  • 最后按照提示进行购买。
  • 购买后等待机器部署完毕,点击刚刚创建好的服务器,进入管理面板,找到远程连接相关信息。

  • 我们使用 PowerShell 进行 SSH 远程连接到服务器,Win+R 打开运行窗口,输入 powershell 后点击确定。

  • 输入 ssh root@你的服务器IP 例如 ssh root@154.9.227.239 回车后,首次需要输入 yes,再次回车后即可登录服务器。

  • 到此为止,我们的云服务器就远程连接上了。

安装和配置步骤

1. 理解 Logrotate 指令

在深入研究高级配置之前,了解 Logrotate 提供的一些关键指令非常重要:

  • maxsize [size]: 如果日志增长到大于指定的大小,则轮转日志 (例如,maxsize 100M)。
  • minsize [size]: 仅当日志达到最小大小时才轮转日志 (例如,minsize 1M)。
  • dateext: 在轮转时将当前日期附加到文件名,使其更容易识别日志。
  • olddir [directory]: 将旧日志移动到轮转后指定的目录。
  • prerotate/postrotate: 在日志轮转之前或之后运行脚本,允许自定义操作,例如通知服务。

2. 配置基于日期的 Logrotate 日志命名

使用 dateext 选项,Logrotate 可以将日期附加到轮转后的日志文件,从而更容易跟踪一段时间内的日志。

编辑特定应用程序的配置文件,例如 Nginx:

sudo nano /etc/logrotate.d/nginx

添加 dateext 选项:

/var/log/nginx/*.log {
    daily
    dateext
    dateformat -%Y-%m-%d
    rotate 7
    compress
    delaycompress
    missingok
    notifempty
    create 0640 www-data adm
    sharedscripts
    postrotate
        [ -f /var/run/nginx.pid ] && kill -USR1 `cat /var/run/nginx.pid`
    endscript
}
  • dateext: 将日期添加到轮转后的日志文件 (例如,access.log-2024-08-13)。
  • dateformat: 自定义日期格式;此处设置为 YYYY-MM-DD。

3. 使用基于大小的日志轮转

对于生成大量日志的应用程序,基于文件大小进行轮转可能比基于时间的轮转更有效。

编辑应用程序的配置文件:

sudo nano /etc/logrotate.d/app

实施基于大小的轮转:

/var/log/app/*.log {
    size 100M
    rotate 10
    compress
    delaycompress
    missingok
    notifempty
    create 0640 appuser appgroup
    sharedscripts
    postrotate
        systemctl restart app
    endscript
}
  • size 100M: 当日志超过 100MB 时轮转日志。
  • rotate 10: 保留最近 10 个轮转的日志。

4. 处理跨多个服务器的日志轮转

在分布式环境中,日志可能分布在多个服务器上。使用 copytruncate 选项可以帮助管理日志而不会中断服务。

使用 copytruncate 配置 Logrotate:

sudo nano /etc/logrotate.d/multi-server-app

添加 copytruncate 选项:

/var/log/multi-server-app/*.log {
    daily
    size 200M
    rotate 5
    compress
    copytruncate
    missingok
    notifempty
    create 0640 appuser appgroup
    sharedscripts
    postrotate
        ssh user@other-server 'sudo systemctl restart app'
    endscript
}
  • copytruncate: 复制日志文件,然后截断原始文件。当应用程序在轮转期间无法关闭日志文件时,此选项非常有用。
  • 使用 SSH 的 postrotate: 在轮转后重新启动另一台服务器上的服务。

5. Logrotate 中的自定义脚本

可以在日志轮转之前或之后执行自定义脚本,以执行诸如通知管理员或将日志备份到远程服务器之类的操作。

编辑配置文件:

sudo nano /etc/logrotate.d/custom-scripts

添加自定义脚本:

/var/log/custom-app/*.log {
    weekly
    rotate 4
    compress
    missingok
    notifempty
    create 0640 customuser customgroup
    prerotate
        # Notify admin before rotation
        echo "Log rotation starting for custom-app logs" | mail -s "Logrotate Notice" admin@example.com
    endscript
    postrotate
        # Backup logs to a remote server
        rsync -av /var/log/custom-app/*.log remoteuser@remote-server:/backup/logs/
    endscript
}
  • prerotate/endscript: 在轮转开始之前运行命令。
  • postrotate/endscript: 在轮转完成后执行命令。

6. 基于年龄和大小组合轮转日志

你可能希望根据年龄和大小轮转日志,确保日志在一定时间后或达到特定大小时进行轮转。

编辑配置文件:

sudo nano /etc/logrotate.d/combined

组合年龄和大小轮转:

/var/log/combined-app/*.log {
    daily
    size 50M
    rotate 7
    compress
    missingok
    notifempty
    create 0640 combineduser combinedgroup
    sharedscripts
    postrotate
        systemctl reload combined-app
    endscript
}

日志将每天轮转或在达到 50MB 时轮转,以先到者为准。

7. 为记录到标准输出的应用程序配置 Logrotate

可以通过重定向日志来管理记录到标准输出的应用程序(例如,Docker 容器)。

为应用程序创建自定义日志文件:

sudo mkdir -p /var/log/custom-app

将标准输出重定向到日志文件:

custom-app > /var/log/custom-app/output.log 2>&1 &

配置 Logrotate:

sudo nano /etc/logrotate.d/custom-app

添加以下配置:

/var/log/custom-app/output.log {
    daily
    rotate 10
    compress
    delaycompress
    copytruncate
    missingok
    notifempty
    postrotate
        systemctl restart custom-app
    endscript
}

结尾

通过利用 Logrotate 的高级配置,你可以有效地管理各种场景中的日志,从处理大规模环境到集成自定义脚本和管理跨多个服务器的日志。根据你的特定需求定制 Logrotate 可确保你的日志得到有效维护,避免磁盘空间问题,并确保在需要时始终可以使用关键的日志信息。

雨云 - 新一代云服务提供商: https://rainyun.ivwv.site
我的博客:https://blog.ivwv.site


http://www.kler.cn/a/469246.html

相关文章:

  • 使用WebSocket 获取实时数据
  • MOE怎样划分不同专家:K-Means聚类算法来实现将神经元特征聚类划分
  • PINN模型详解
  • SUB输入5V升压充电16.8V芯片HU5912
  • 海外招聘丨 弗拉瑞克商学院—博士研究员:智能家居技术业务和能源管理中的数据分析和人工智能
  • MarkDown 的 mermaid gantt(甘特图)、mermaid sequenceDiagram (流程图) 语法解析和应用
  • Go语言的 的数据封装(Data Encapsulation)基础知识
  • 关于Hugging Face模型国内下载
  • Kotlin 数据类与密封类
  • Linux下学【MySQL】表中修改和删除的进阶操作(配实操图和SQL语句通俗易懂)
  • 开源模型应用落地-Qwen2.5-7B-Instruct与vllm实现推理加速的正确姿势-利用KOR框架实现结构化输出(七)
  • 【汇编语言】外中断(二)—— 键盘的奥秘:编写自己的 int 9 中断例程
  • 【软考网工笔记】操作系统管理与配置——Windows
  • Python中使用PostgreSQL和Apache AGE扩展来绘制和显示图表
  • Go语言的 的变量声明(Variable Declaration)基础知识
  • MySQL叶子节点为啥使用双向链表?不使用单向呢?
  • centos7yum安装mysql5.7
  • 【机器学习:三、常见的代价函数】
  • JS实现SVG的TEXT标签自动换行功能
  • [CTF/网络安全] 攻防世界 view_source 解题详析
  • UE5失真材质
  • 3.6 高级树形数据结构(2-3-4树、B树、B+树、哈夫曼树等)
  • 【HF设计模式】05-单例模式
  • 深入Android架构(从线程到AIDL)_09 认识Android的主线程
  • MATLAB R2015b安装、激活记录少走弯路
  • 【Unity Shader】【图形渲染】Unity Shader操作基础5-Unity Shader调试技巧