logrotate日志切割配置

简介:

1 logrotate介绍

logrotate软件是一个日志管理工具,用于非分隔日志,删除旧的日志文件,并创建新的日志文件,起到转储作用,可以为系统节省磁盘空间。一般centos系统已经自带安装好了。

logrotate是基于crontab运行的,其脚本是/etc/cron.daily/logtotate,日志轮转是系统自发完成的,实际运行时,logrotate会调用配置文件/etc/logrotate.conf。可以在/etc/logrotate.d目录里放置自定义好的配置文件,用来覆盖logrotate.conf的缺省值。

2 logrotate常用配置文件

/etc/logrotate.conf     主配置文件

/etc/logrotate.d/       该目录里的所有文件都会自动被读入到logrotate.conf文件中

2.1 logrotate.conf

# sed -r '/^$|^#/d' /etc/logrotate.conf

weekly    #默认每周执行一次日志轮询

rotate 4   #默认保留4个日志文件

create    #自动创建新的日志文件,新的文件和原来的文件具有相同的权限

dateext   #切割后的日志文件以当前日期为结尾,如xxx.log-2018-2-28

include /etc/logrotate.d      #logrotate.d目录里的文件加载进来

/var/log/wtmp {            #针对wtmp日志设定的参数

    monthly               #每个月切割一次,取代默认的一周

    create 0664 root utmp   #新建日志权限为0664,属主为root,属组为utmp

    minsize 1M            #文件大小超过一周后才会切割

    rotate 1               #只保留一个日志

}

/var/log/btmp {

    missingok

    monthly

    create 0600 root utmp

    rotate 1

}

2.2 常用参数

compress                     通过gzip 压缩转储以后的日志

nocompress                   不做gzip压缩处理

copytruncate                  用于还在打开中的日志文件,把当前日志备份并截断;是先拷贝再清空的方式,拷贝和清空之间有一个时间差,可能会丢失部分日志数据。

nocopytruncate                备份日志文件不过不截断

create mode owner group        轮转时指定创建新文件的属性,如create 0777 nobody nobody

nocreate                      不建立新的日志文件

delaycompress                 compress 一起使用时,转储的日志文件到下一次转储时才压缩

nodelaycompress               覆盖 delaycompress 选项,转储同时压缩。

missingok                     如果日志丢失,不报错继续滚动下一个日志

errors address                  转储时的错误信息发送到指定的Email 地址

ifempty                       即使日志文件为空文件也做轮转,这个是logrotate的缺省选项。

notifempty                    当日志文件为空时,不进行轮转

mail address                   把转储的日志文件发送到指定的E-mail 地址

nomail                       转储时不发送日志文件

olddir directory                转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统

noolddir                     转储后的日志文件和当前日志文件放在同一个目录下

sharedscripts                 运行postrotate脚本,作用是在所有日志都轮转后统一执行一次脚本。如果没有配置这个,那么每个日志轮转后都会执行一次脚本

prerotate             logrotate转储之前需要执行的指令,例如修改文件的属性等动作;必须独立成行

postrotate            logrotate转储之后需要执行的指令,例如重新启动 (kill -HUP) 某个服务!必须独立成行

daily                 指定转储周期为每天

weekly               指定转储周期为每周

monthly              指定转储周期为每月

rotate count           指定日志文件删除之前转储的次数,指没有备份,指保留个备份

dateext               使用当期日期作为命名格式

dateformat .%s         配合dateext使用,紧跟在下一行出现,定义文件切割后的文件名,必须配合dateext使用,只支持%Y %m %d %s 这四个参数

size(minsize) log-size   当日志文件到达指定的大小时才转储,log-size能指定bytes(缺省)KB (sizek)MB(sizem).

当日志文件 >= log-size 的时候就转储。 以下为合法格式:(其他格式的单位大小写没有试过)

size = 5  size 5 >= 5 个字节就转储)

size = 100k  size 100k

size = 100M  size 100M

3 nginx日志切割实例

vim /etc/logrotate.d/nginx   #创建nginx日志切割配置文件

/application/nginx/logs/*.log{

daily

rotate 10

create

dateext

}

# logrotate -d /etc/logrotate.d/nginx    调试测试   -d debug

# logrotate -d /etc/logrotate.d/nginx    手动切割日志测试

# ls /application/nginx/logs/           带日期的表示是切割好的日志

access.log           bbs.log-20180228   error.log           www.log

access.log-20180228  blog.log           error.log-20180228  www.log-20180228

bbs.log              blog.log-20180228  nginx.pid

配置好nginx切割日志生效时间

# cat /etc/anacrontab    #此文件里有生效时间

# /etc/anacrontab: configuration file for anacron

 

# See anacron(8) and anacrontab(5) for details.

 

SHELL=/bin/sh

PATH=/sbin:/bin:/usr/sbin:/usr/bin

MAILTO=root

# the maximal random delay added to the base delay of the jobs

RANDOM_DELAY=45

# the jobs will be started during the following hours only

START_HOURS_RANGE=3-22   #生效时间范围是3点到22

 

#period in days   delay in minutes   job-identifier   command

1       5       cron.daily              nice run-parts /etc/cron.daily

7       25      cron.weekly             nice run-parts /etc/cron.weekly

@monthly 45     cron.monthly            nice run-parts /etc/cron.monthly

也就是说,配好的nginx切割日志,生效时间是在凌晨3点到22点之间,而且随机延迟时间是45分钟

 



本文转自 茁壮的小草 51CTO博客,原文链接:http://blog.51cto.com/wn2100/2074048,如需转载请自行联系原作者

相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
2月前
|
监控 安全 程序员
Python日志模块配置:从print到logging的优雅升级指南
从 `print` 到 `logging` 是 Python 开发的必经之路。`print` 调试简单却难维护,日志混乱、无法分级、缺乏上下文;而 `logging` 支持级别控制、多输出、结构化记录,助力项目可维护性升级。本文详解痛点、优势、迁移方案与最佳实践,助你构建专业日志系统,让程序“有记忆”。
269 0
|
3月前
|
缓存 Java 应用服务中间件
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
本文详解Spring Boot十大核心配置优化技巧,涵盖Tomcat连接池、数据库连接池、Jackson时区、日志管理、缓存策略、异步线程池等关键配置,结合代码示例与通俗解释,助你轻松掌握高并发场景下的性能调优方法,适用于实际项目落地。
631 5
|
9月前
|
SQL Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— application.yml 中对日志的配置
在 Spring Boot 项目中,`application.yml` 文件用于配置日志。通过 `logging.config` 指定日志配置文件(如 `logback.xml`),实现日志详细设置。`logging.level` 可定义包的日志输出级别,例如将 `com.itcodai.course03.dao` 包设为 `trace` 级别,便于开发时查看 SQL 操作。日志级别从高到低为 ERROR、WARN、INFO、DEBUG,生产环境建议调整为较高级别以减少日志量。本课程采用 yml 格式,因其层次清晰,但需注意格式要求。
868 0
|
安全 BI 网络安全
EventLog Analyzer 如何满足等保合规要求?密码有效期、产品日志保留、配置备份三大核心问题全面解答
EventLog Analyzer(ELA)助力企业满足网络安全等级保护要求,支持配置自动/手动备份、日志180天留存及密码策略管理,提升合规性与安全运营效率。
132 0
|
5月前
|
JSON 安全 Go
Go语言项目工程化 —— 日志、配置、错误处理规范
本章详解Go语言项目工程化核心规范,涵盖日志、配置与错误处理三大关键领域。在日志方面,强调其在问题排查、性能优化和安全审计中的作用,推荐使用高性能结构化日志库zap,并介绍日志级别与结构化输出的最佳实践。配置管理部分讨论了配置分离的必要性,对比多种配置格式如JSON、YAML及环境变量,并提供viper库实现多环境配置的示例。错误处理部分阐述Go语言显式返回error的设计哲学,讲解标准处理方式、自定义错误类型、错误封装与堆栈追踪技巧,并提出按调用层级进行错误处理的建议。最后,总结各模块的工程化最佳实践,助力构建可维护、可观测且健壮的Go应用。
|
6月前
|
存储 NoSQL MongoDB
Docker中安装MongoDB并配置数据、日志、配置文件持久化。
现在,你有了一个运行在Docker中的MongoDB,它拥有自己的小空间,对高楼大厦的崩塌视而不见(会话丢失和数据不持久化的问题)。这个MongoDB的数据、日志、配置文件都会妥妥地保存在你为它精心准备的地方,天旋地转,它也不会失去一丁点儿宝贵的记忆(即使在容器重启后)。
742 4
|
8月前
|
存储 监控 API
【Azure App Service】分享使用Python Code获取App Service的服务器日志记录管理配置信息
本文介绍了如何通过Python代码获取App Service中“Web服务器日志记录”的配置状态。借助`azure-mgmt-web` SDK,可通过初始化`WebSiteManagementClient`对象、调用`get_configuration`方法来查看`http_logging_enabled`的值,从而判断日志记录是否启用及存储方式(关闭、存储或文件系统)。示例代码详细展示了实现步骤,并附有执行结果与官方文档参考链接,帮助开发者快速定位和解决问题。
271 22
|
9月前
|
监控 Shell Linux
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。
|
9月前
|
数据库连接 测试技术 Windows
【YashanDB知识库】windows配置ODBC跟踪日志, 使用日志定位问题
【YashanDB知识库】windows配置ODBC跟踪日志, 使用日志定位问题
南大通用GBase 8a配置gcware日志等级,减少日志输出,节省磁盘IO
南大通用GBase 8a配置gcware日志等级,减少日志输出,节省磁盘IO

热门文章

最新文章