nginx日志切割

shell脚本实现nginx日志切割

1、编写自动分割Nginx日志脚本

#!/bin/bash  
#Rotate the Nginx logs to prevent a single logfile from consuming too much disk space.   
#Nginx 日志文件所在的目录
LOGS_PATH=/opt/nginx/logs/nginx
#获取昨天的yyyy-MM-dd(2017-11-14)
YESTERDAY=$(date -d "yesterday" +%Y-%m-%d)
或获取昨天的yyyyMMdd(20171114)
YESTERDAY=$(date -d "yesterday" +%Y%m%d)
#保留30天日志
save_days=30
#移动文件 
mv ${LOGS_PATH}/access.log ${LOGS_PATH}/access_${YESTERDAY}.log  
mv ${LOGS_PATH}/error.log ${LOGS_PATH}/error_${YESTERDAY}.log  
#向 Nginx 主进程发送 USR1 信号。USR1 信号是重新打开日志文件 
#kill -USR1 等于 nginx -s reopen
#这个信号量本来就是用于重新读取日志文件的
#kill -USR2 等于 nginx -s reload
#reload 和 reopen 的行为相差很大,reopen 仅仅检查日志文件,reload 会重载配置,并启动新 worker,关闭旧 worker
kill -USR1 $(cat /opt/nginx/run/nginx/nginx.pid)  
#delete 30 days ago nginx log files
find $LOGS_PATH -mtime +$save_days -exec rm -f {} \;

给脚本加上执行权限
chmod +x /opt/nginx/cut-nginxlog.sh

2、设置Linux定时任务

vi  /etc/crontab

使用bash 或sh、root来执行bash shell脚本:

0 0 * * * /bin/sh /opt/nginx/cut-nginxlog.sh > /dev/null 2>&1
0 0 * * * bash /opt/nginx/cut-nginxlog.sh
0 0 * * * root /opt/nginx/cut-nginxlog.sh;

说明:
从command>/dev/null说起
其实这条命令是一个缩写版,对于一个重定向命令,肯定是a > b这种形式,那么command > /dev/null难道是command充当a的角色,/dev/null充当b的角色。这样看起来比较合理,其实一条命令肯定是充当不了a,肯定是command执行产生的输出来充当a,其实就是标准输出stdout。所以command > /dev/null相当于执行了command 1 > /dev/null。执行command产生了标准输出stdout(用1表示),重定向到/dev/null的设备文件中。

2>&1
几个基本符号及其含义
/dev/null 表示空设备文件
0 表示stdin标准输入
1 表示stdout标准输出
2 表示stderr标准错误

有时候希望将错误的信息重新定向到输出,就是将2的结果重定向至1中就有了"2>1"这样的思路,如果按照上面的写法,系统会默认将错误的信息(STDERR)2重定向到一个名字为1的文件中,而非所想的(STDOUT)中。因此需要加&进行区分。就有了 2>&1 这样的用法,这里&相当于等效于标准输出

3、shell定时删除nginx日志

创建dellog.sh文件,路径/opt/nginx
vi dellog.sh
#!/bin/sh
find /opt/nginx/logs/nginx/error -mtime +7 -type f -name *.log | xargs rm -f
find /opt/nginx/logs/nginx/access -mtime +7 -type f -name *.log | xargs rm -f
#定期删除七天前的日志文件

有时为了验证脚本执行内容可以打印到test.log查看是否正确的:
0 0 * /opt/nginx/cut-nginxlog.sh > /var/tmp/test.log 2>&1

转载于:https://blog.51cto.com/meiling/2044792

你可能感兴趣的:(运维,shell,操作系统)