改变nginx logrotate方式采用sh文件自动切割日志文件

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

Logrotate读取/etc/logrotate.d目录下的文件
这里的文件会被系统自动执行
logrotate是作为linux系统日志的管理工具存在。他可以轮换,压缩,邮件系统日志文件。
默认的logrotate被加入cron的/etc/cron.daily中作为每日任务执行。
/etc/logrotate.conf为其默认配置文件指定每个日志文件的默认规则。
/etc/logrotate.d/* 为/etc/logrotate.conf默认包含目录其中文件也会被logrotate读取。指明每个日志文件的特定规则。
/var/lib/logrotate/status中默认记录logrotate上次轮换日志文件的时间。

翻开叫nginx这个文件内容如下

1
2
3
4
5
6
7
8
9
10
11
12
13
/var/log/nginx/ *.log {
         daily
         missingok
         rotate 52
         compress
         delaycompress
         notifempty
         create 640 nginx adm
         sharedscripts
         postrotate
                 [ -f  /var/run/nginx .pid ] &&  kill  -USR1 ` cat  /var/run/nginx .pid`
         endscript
}

解释
daily 脚本按天执行
missingok 当日志为空不进行翻滚
rotate 52 当日志超过52个之后,从头开始,即第53个会覆盖第一个
compress gzip压缩,nocompress表示不压缩,如果是httpd一定要压缩,这太占硬盘了
delaycompress 延迟压缩
prerotate 开始滚动日志的时候执行的代码
postrotate 滚动日志后执行的代码 可以看到nginx在滚动之后会执行一句shell ,用来让nginx重新生成日志
全部参数详情
compress 通过gzip 压缩转储以后的日志
nocompress 不需要压缩时,用这个参数
copytruncate 用于还在打开中的日志文件,把当前日志备份并截断
nocopytruncate 备份日志文件但是不截断
create mode owner group 转储文件,使用指定的文件模式创建新的日志文件
nocreate 不建立新的日志文件
delaycompress 和 compress 一起使用时,转储的日志文件到下一次转储时才压缩
nodelaycompress 覆盖 delaycompress 选项,转储同时压缩。
errors address 专储时的错误信息发送到指定的Email 地址
ifempty 即使是空文件也转储,这个是 logrotate 的缺省选项。
notifempty 如果是空文件的话,不转储
mail address 把转储的日志文件发送到指定的E-mail 地址
nomail 转储时不发送日志文件
olddir directory 转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统
noolddir 转储后的日志文件和当前日志文件放在同一个目录下
prerotate/endscript 在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行
postrotate/endscript 在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行
daily 指定转储周期为每天
weekly 指定转储周期为每周
monthly 指定转储周期为每月
rotate count 指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份
tabootext [+] list 让logrotate 不转储指定扩展名的文件,缺省的扩展名是:.rpm-orig, .rpmsave, v, 和 ~
size size 当日志文件到达指定的大小时才转储,Size 可以指定 bytes (缺省)以及KB (sizek)或者MB (sizem).
具体执行时间没怎么搞明白。我的系统里每天是7.35左右发生第一条日志,说明在7:35 执行了这个命令。但是时间不固定。目前推测为系统滚动日志按天的计划很多要一个一个的做。大家排队。
所以使用这种默认的日志切割方式,无法比较准确的按天来分日志。(理想的方式从0:00:00开始分日志。)
日志切割操作办法第一步:删除原来自动切割
所以删除这个方式的小办法就是删除/etc/logrotate.d/nginx 这个文件
来个脚本试试
日志切割操作办法第二步
功能点:
1.自动按天切割日志
2.按时间排放文件夹
3.保留30天的日志文件
4.自动压缩日志文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#!/bin/bash
#set the path to nginx log files
log_files_path= "/var/log/nginx/"
log_files_dir=${log_files_path}$( date  -d  "yesterday"  + "%Y" )/$( date  -d  "yesterday"  + "%m" )
#set nginx log files you want to cut
log_files_name=(access error)
#set the path to nginx.
nginx_sbin= "/etc/init.d/nginx"
#Set how long you want to save
save_days=30
  ############################################
#Please do not modify the following script #
############################################
mkdir  -p $log_files_dir
  log_files_num=${ #log_files_name[@]}
  #cut nginx log files
for ((i=0;i<$log_files_num;i++)); do
mv  ${log_files_path}${log_files_name[i]}.log ${log_files_dir}/${log_files_name[i]}_$( date  -d  "yesterday"  + "%Y%m%d" ).log
gzip  ${log_files_dir}/${log_files_name[i]}_$( date  -d  "yesterday"  + "%Y%m%d" ).log 
done
  #delete 30 days ago nginx log files
find  $log_files_path -mtime +$save_days - exec  rm  -rf {} \; 
  $nginx_sbin  reload

用这个脚本,设置为0:00:00开始执行,这样就可以基本在0点进行日志快速切割了。
将脚本设置到crontab 里就好了。



本文转自 boy461205160 51CTO博客,原文链接:http://blog.51cto.com/461205160/1741264

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
2月前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
本文介绍了MySQL InnoDB存储引擎中的数据文件和重做日志文件。数据文件包括`.ibd`和`ibdata`文件,用于存放InnoDB数据和索引。重做日志文件(redo log)确保数据的可靠性和事务的持久性,其大小和路径可由相关参数配置。文章还提供了视频讲解和示例代码。
180 11
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
|
2月前
|
SQL Oracle 关系型数据库
【赵渝强老师】Oracle的控制文件与归档日志文件
本文介绍了Oracle数据库中的控制文件和归档日志文件。控制文件记录了数据库的物理结构信息,如数据库名、数据文件和联机日志文件的位置等。为了保护数据库,通常会进行控制文件的多路复用。归档日志文件是联机重做日志文件的副本,用于记录数据库的变更历史。文章还提供了相关SQL语句,帮助查看和设置数据库的日志模式。
【赵渝强老师】Oracle的控制文件与归档日志文件
|
1月前
|
监控 应用服务中间件 定位技术
要统计Nginx的客户端IP,可以通过分析Nginx的访问日志文件来实现
要统计Nginx的客户端IP,可以通过分析Nginx的访问日志文件来实现
152 3
|
2月前
|
SQL 关系型数据库 MySQL
【赵渝强老师】MySQL的全量日志文件
MySQL全量日志记录所有操作的SQL语句,默认禁用。启用后,可通过`show variables like %general_log%检查状态,使用`set global general_log=ON`临时开启,执行查询并查看日志文件以追踪SQL执行详情。
|
2月前
|
Oracle 关系型数据库 数据库
【赵渝强老师】Oracle的参数文件与告警日志文件
本文介绍了Oracle数据库的参数文件和告警日志文件。参数文件分为初始化参数文件(PFile)和服务器端参数文件(SPFile),在数据库启动时读取并分配资源。告警日志文件记录了数据库的重要活动、错误和警告信息,帮助诊断问题。文中还提供了相关视频讲解和示例代码。
|
3月前
|
监控 Linux 应用服务中间件
系统监控:使用日志文件 journalctl的使用
本文介绍了如何使用`journalctl`命令来监控和查看Linux系统的日志文件,包括查看特定行数、过滤日志级别、实时跟踪日志、按时间段查询日志以及日志轮换和压缩的配置。
140 2
系统监控:使用日志文件 journalctl的使用
|
3月前
|
SQL 数据库
为什么 SQL 日志文件很大,我应该如何处理?
为什么 SQL 日志文件很大,我应该如何处理?
|
3月前
|
开发工具 git
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
55 1
|
3月前
|
JavaScript 前端开发 应用服务中间件
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
247 0
|
3月前
|
SQL 数据库
为什么SQL日志文件很大,该如何处理?
为什么SQL日志文件很大,该如何处理?