Nginx按天分割轮询日志文件

类型: 物联网 作者: nonghuo 时间: 2020-05-26 阅读数: 84 删除 审核 反审核 站点推荐
使用linux系统自带的日志轮询工具logrotate logrotate 介绍 ------------------------------------- logrotate 程序是一个日志文件管理工具。用来把旧的日志文件删除,并创建新的日志文件,我们把它叫做“转储”。我们可以根据日志文件的大小,也可以根据其天数来转储,这个过程一般通过cron 程序来执行。 logrotate 程序还可以用于压缩日志文件,以及发送日志到指定的e-mail 。 logrotate 的配置文件是/etc/logrotate.conf。主要参数如下表: 参数 功能 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). nginx日志文件access.log的轮询实例(redhat linux) ------------------------------------------------------------------------------ nginx安装在目录/usr/local/nginx nginx的access.log日志存放在/usr/local/nginx/logs/access.log

第一步:

在/etc/logrotate.d/文件目录下添加一个nginx文件内容如下
/usr/local/nginx/logs/access.log {
daily
rotate 365
postrotate
/bin/kill -usr1 `/bin/cat /usr/local/nginx/logs/nginx.pid`
endscript
}
需要注意的是/etc/logrotate.conf中的include /etc/logrotate.d需要处于非注释状态

第二步:

logrotate是作为linux系统日志的管理工具存在。他可以轮换,压缩,邮件发送系统日志文件。默认的logrotate被加入cron(cron是一个linux下 的定时执行工具 ,可以在无需人工干预的情况下运行作业)的/etc/cron.daily中作为每日任务执行。/var/lib/logrotate/statue中默认记录logrotate上次轮换日志文件的时间。 因此要实现日志的自动轮询还需要配置cron的/etc/crontab文件,如下:
shell=/bin/bash
path=/sbin:/bin:/usr/sbin:/usr/bin
mailto=root
home=/

# for details see man 4 crontabs

# example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) or jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (sunday=0 or 7) or sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name command to be executed
  59  23  *  *  * root run-parts /etc/cron.daily
上面表示每天的 23:59 执行/etc/cron.daily目录中的所有可执行文件 配置完成后重启cron服务。 /sbin/service crond start //启动服务 /sbin/service crond stop //关闭服务 /sbin/service crond restart //重启服务

/sbin/service crond reload //重新载入配置

这样,每天都会自动轮询,生成access.log - n日志了

来自Lujishu-lujishu.net的文章,链接:http://article.lujishu.net/viewarticle/220151002905062。本文章由作者发布,不代表本站观点,如有侵权,请联系我们撤下该文章。

在此注入作者简介

注册时间: 2012-07-07

  • 文章量
    4
  • 访问量
    74

站点推荐

地摊真的会影响商业地产吗

管理员

关于Spark集群的启动命令大全

thincladt

在Easyui中怎么设置datagrid来自适应屏幕的宽度 你知道吗

nongzuo

大数据平台定义及技术方案和路线

laurustin

如何用Python 将图片和矩阵进行互相转换

langdang

在matlab中图像如何用imwrite()保存

jinpu

计算各种标准差的代码怎么写

outdoersa

在python中修改Dataframe列名,怎么做

jinghuhui

人工智能-人脸识别之人脸姿态

consuwpso

linux 如何再次获取 dhcp 的ip地址

incestsih