logrotate 日志文件管理工具介绍和经典案例

目录

1.使用介绍

2.经典例子

[2.1 基本配置示例](#2.1 基本配置示例)

[2.2 按大小轮转示例【推荐】](#2.2 按大小轮转示例【推荐】)

[2.3 包含额外配置文件](#2.3 包含额外配置文件)

[2.4 个人工作中使用案例](#2.4 个人工作中使用案例)


`logrotate` 是一个日志文件管理工具,用于定期轮转、压缩和删除日志文件,以防止日志文件无限增长导致磁盘空间耗尽。下面是 `logrotate` 的简单介绍和一些经典例子:

1.使用介绍

  1. 配置文件:`logrotate` 的配置文件通常位于 `/etc/logrotate.conf` 或者 `/etc/logrotate.d/` 目录下,每个配置文件对应一个日志文件的轮转设置。

  2. 轮转周期:可以通过配置文件指定日志文件的轮转周期,例如每天、每周或每月等。

  3. 保留备份:可以设置保留多少个轮转后的备份文件,避免占用过多磁盘空间。

  4. 压缩选项:可以配置是否对轮转后的日志文件进行压缩处理。

2.经典例子

2.1 基本配置示例

bash 复制代码
/var/log/myapp.log {
   daily
   rotate 7
   compress
   missingok
   notifempty
}

上面参数说明:

  • `daily`:每天轮转一次。

  • `rotate 7`:保留最近 7 个轮转后的备份文件。

  • `compress`:对轮转后的备份文件进行压缩。

  • `missingok`:如果日志文件不存在,则忽略错误继续。

  • `notifempty`:如果日志文件为空,则不轮转。

2.2 按大小轮转示例【推荐】

bash 复制代码
/var/log/myapp.log {
   size 100M
   rotate 5
   compress
}

上面参数说明:

  • `size 100M`:当日志文件达到 100MB 时进行轮转。

  • `rotate 5`:保留最近 5 个轮转后的备份文件。

  • `compress`:对轮转后的备份文件进行压缩。

2.3 包含额外配置文件

在 `/etc/logrotate.conf` 中可以使用 `include` 指令包含其他配置文件:

bash 复制代码
include /etc/logrotate.d/*

这些例子展示了 `logrotate` 的基本用法和配置方式。根据实际需求和日志文件的特点,可以灵活配置 `logrotate`,以确保日志文件得到有效管理和轮转。

2.4 个人工作中使用案例

(1)自动轮转:创建文件bcsc-platfrom-system-start,文件内容如下,然后把文件丢到这个目录下面:/etc/logrotate.d/ 系统就会自动轮询。

bash 复制代码
/home/facePay/platform-9022/logs/console.log{

    copytruncate

    rotate 50

    missingok

    compress

    size 100M

}

(2)手动轮转:跟平常开发项目一样,想手动测试一次定时任务,就用下面命令进行操作:

bash 复制代码
logrotate --force  /etc/logrotate.d/bcsc-platfrom-system-start

上面参数说明:

  • `copytruncate` 参数是用于告诉 `logrotate` 在轮转日志文件时采取的一种特殊操作。通常,在轮转日志文件时,`logrotate` 会创建一个新的空日志文件来接收新的日志内容,然后将旧的日志文件进行重命名或者压缩。但是在某些情况下,如果日志文件正在被某个进程打开并写入,直接轮转会导致该进程继续往已经重命名的日志文件中写入数据,导致日志丢失或者混乱。

这时候就可以使用 `copytruncate` 参数,它的作用是在轮转日志文件时,`logrotate` 会首先创建一个新的空日志文件来接收新的日志内容,然后将旧的日志文件进行重命名,但不断开与原日志文件相关的文件描述符,而是使用 `cp` 命令来复制原始文件的内容到新文件,再使用 `truncate` 命令将原始文件截断为0字节,这样就能保证日志文件的连续性,避免了因为关闭日志文件导致的日志丢失或者混乱。

因此,`copytruncate` 参数在某些需要连续性的日志文件轮转场景中非常有用,可以确保日志文件在轮转过程中不会丢失任何日志信息。

  • `rotate 50`:保留最近 50 个轮转后的备份文件。

  • `compress`:对轮转后的备份文件进行压缩。

  • `missingok`:如果日志文件不存在,则忽略错误继续。

  • `notifempty`:如果日志文件为空,则不轮转。

  • `size 100M`:当日志文件达到 100MB 时进行轮转。

介绍完毕,感谢阅读,如果文章对您有帮忙,麻烦点个赞。

相关推荐
前端张三8 分钟前
Mac 电脑pink 后端ip地址进行本地联调
服务器·tcp/ip·macos
程序员-珍11 分钟前
使用openapi生成前端请求文件报错 ‘Token “Integer“ does not exist.‘
java·前端·spring boot·后端·restful·个人开发
第六五16 分钟前
ubuntu命令行连接wifi
服务器·ubuntu
CXDNW19 分钟前
【网络篇】计算机网络——应用层详述(笔记)
服务器·笔记·计算机网络·http·web·cdn·dns
zeruns80232 分钟前
如何搭建自己的域名邮箱服务器?Poste.io邮箱服务器搭建教程,Linux+Docker搭建邮件服务器的教程
linux·运维·服务器·docker·网站
2401_8572979138 分钟前
招联金融2025校招内推
java·前端·算法·金融·求职招聘
北城青39 分钟前
WebRTC Connection Negotiate解决
运维·服务器·webrtc
福大大架构师每日一题1 小时前
23.1 k8s监控中标签relabel的应用和原理
java·容器·kubernetes
Hugo_McQueen1 小时前
pWnos1.0 靶机渗透 (Perl CGI 的反弹 shell 利用)
linux·服务器·网络安全
金灰1 小时前
HTML5--裸体回顾
java·开发语言·前端·javascript·html·html5