阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Nginx按天分割轮询日志文件

133次阅读
没有评论

共计 5535 个字符,预计需要花费 14 分钟才能阅读完成。

使用 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).

————————————– 分割线 ————————————–

CentOS 6.2 实战部署 Nginx+MySQL+PHP http://www.linuxidc.com/Linux/2013-09/90020.htm

使用 Nginx 搭建 WEB 服务器 http://www.linuxidc.com/Linux/2013-09/89768.htm

搭建基于 Linux6.3+Nginx1.2+PHP5+MySQL5.5 的 Web 服务器全过程 http://www.linuxidc.com/Linux/2013-09/89692.htm

CentOS 6.3 下 Nginx 性能调优 http://www.linuxidc.com/Linux/2013-09/89656.htm

CentOS 6.3 下配置 Nginx 加载 ngx_pagespeed 模块 http://www.linuxidc.com/Linux/2013-09/89657.htm

CentOS 6.4 安装配置 Nginx+Pcre+php-fpm http://www.linuxidc.com/Linux/2013-08/88984.htm

Nginx 安装配置使用详细笔记 http://www.linuxidc.com/Linux/2014-07/104499.htm

Nginx 日志过滤 使用 ngx_log_if 不记录特定日志 http://www.linuxidc.com/Linux/2014-07/104686.htm

————————————– 分割线 ————————————–

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 需要处于非注释状态
 
更多详情见请继续阅读下一页的精彩内容:http://www.linuxidc.com/Linux/2014-07/104687p2.htm

第二步:

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 日志了

Nginx 的详细介绍:请点这里
Nginx 的下载地址:请点这里

使用 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).

————————————– 分割线 ————————————–

CentOS 6.2 实战部署 Nginx+MySQL+PHP http://www.linuxidc.com/Linux/2013-09/90020.htm

使用 Nginx 搭建 WEB 服务器 http://www.linuxidc.com/Linux/2013-09/89768.htm

搭建基于 Linux6.3+Nginx1.2+PHP5+MySQL5.5 的 Web 服务器全过程 http://www.linuxidc.com/Linux/2013-09/89692.htm

CentOS 6.3 下 Nginx 性能调优 http://www.linuxidc.com/Linux/2013-09/89656.htm

CentOS 6.3 下配置 Nginx 加载 ngx_pagespeed 模块 http://www.linuxidc.com/Linux/2013-09/89657.htm

CentOS 6.4 安装配置 Nginx+Pcre+php-fpm http://www.linuxidc.com/Linux/2013-08/88984.htm

Nginx 安装配置使用详细笔记 http://www.linuxidc.com/Linux/2014-07/104499.htm

Nginx 日志过滤 使用 ngx_log_if 不记录特定日志 http://www.linuxidc.com/Linux/2014-07/104686.htm

————————————– 分割线 ————————————–

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 需要处于非注释状态
 
更多详情见请继续阅读下一页的精彩内容:http://www.linuxidc.com/Linux/2014-07/104687p2.htm

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-20发表,共计5535字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中