小知识:Nginx定时切割日志实现详解

前言

Nginx日志默认情况下写入到一个文件中,为了区分各个域下的日志,我们一般会分开存储。即时这样,文件也会变的越来越大,非常不方便查看分析。通常我们是以每日来做统计的,下面来聊聊以日期来分隔Nginx日志。

配置

编写脚本

01#!/bin/bash
02#初始化
03LOGS_PATH=/usr/local/nginx/logs
04YESTERDAY=$(date -d “yesterday” +%Y%m%d)
05
06#按天切割日志
07mv ${LOGS_PATH}/bbs.52itstyle.com.access.log ${LOGS_PATH}/bbs.52itstyle.com.access_${YESTERDAY}.log
08mv ${LOGS_PATH}/blog.52itstyle.com.access.log  ${LOGS_PATH}/blog.52itstyle.com.access_${YESTERDAY}.log
09
10#向nginx主进程发送USR1信号,重新打开日志文件,否则会继续往mv后的文件写数据的。原因在于:linux系统中,内核是根据文件描述符来找文件的。如果不这样操作导致日志切割失败。
11kill -USR1 `ps axu | grep “nginx: master process” | grep -v grep | awk {print $2}`
12
13#删除7天前的日志
14cd ${LOGS_PATH}
15find . -mtime +7 -name “*20[1-9][3-9]*” | xargs rm -f
16
17exit 0

写入任务

1#执行命令
2crontab -e
3#写入文件并保存
40 0 * * * /home/scripts/cut_del_nginx_logs.sh

crontab

crond是linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务工具,并且会自动启动crond进程,crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务。Linux下的任务调度分为两类,系统任务调度和用户任务调度。

系统任务调度:系统周期性所要执行的工作,比如写缓存数据到硬盘、日志清理等。在/etc目录下有一个crontab文件,这个就是系统任务调度的配置文件。

crontab服务安装

安装crontab:

1yum install crontabs

服务操作说明:

1service crond start //启动服务
2service crond stop //关闭服务
3service crond restart //重启服务
4service crond reload //重新载入配置

查看crontab服务状态:

1service crond status

手动启动crontab服务:

1service crond start

查看crontab服务是否已设置为开机启动,执行命令:

加入开机自动启动:

1chkconfig –level 35 crond on

crontab格式说明

用户所建立的crontab文件中,每一行都代表一项任务,每行的每个字段代表一项设置,它的格式共分为六个字段,前五段是时间设定段,第六段是要执行的命令段,格式如下:

%小知识:Nginx定时切割日志实现详解-猿站网-插图

在以上各个字段中,还可以使用以下特殊字符:

星号(*):代表所有可能的值,例如day字段如果是星号,则表示在满足其它字段的制约条件后每天都执行该命令操作。 逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9” 中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6” 正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:一篇非常好的linux学习笔记分享(Linux入门绝佳)

2023-5-19 3:21:24

建站知识

小知识:常用的Linux shell命令详解收集整理

2023-5-19 3:29:33

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索