nginx是一款非常棒的web服务器,但是在网站高访问量的情况下,每天的日志文件就会非常大。占用非常多的磁盘空间,因此要进行定期清理
文件路径/usr/local/nginx/clear_log.sh
vi clear_log.sh。输入如下内容
#!/bin/bash
cp /usr/local/nginx/logs/error.log /usr/local/nginx/error-$(date -d "yesterday" +"%Y%m%d").log
/#先复制原来的错误日志文件,请根据自己实际的日志路径填写
cat /dev/null > /usr/local/nginx/logs/error.log
/#清空错误日志文件
cp/usr/local/nginx/logs/access.log /var/log/nginx/access/access-$(date -d "yesterday" +"%Y%m%d").log
/#先复制原来的正常访问日志
cat /dev/null > /usr/local/nginx/logs/access.log
/#清空原来的正常访问日志
vi dellog.sh
#!/bin/sh
find /usr/nginx/logs/error -mtime +7 -type f -name \*.log | xargs rm -f
find /usr/nginx/logs/access -mtime +7 -type f -name \*.log | xargs rm -f
/#定期删除七天前的日志文件
vi root //根据此时登录的用户名,例如我此时登录的是root用户,输入如下内容
0 0 * * * /usr/nginx/clear_log.sh
/#每天0点执行/usr/nginx/clear_log.sh
0 0 * * * /usr/nginx/dellog.sh
/#每天 0点执行 /usr/nginx/dellog.sh
保存后退出,输入命令crontab root就会看到/var/spool/cron/文件夹下看到相应的副本文件root。至此完成nginx日志按天拆分与定期清除。
逻辑详解:比如现在是3月18日0点0分,系统会自动执行clear_log.sh与dellog.sh两个shell脚本。 clear_log.sh会把3月17日的日志文件分别生成为access_20140317.log与error_20140318.log,然后把原 来的access.log与error.log分别清空。dellog.sh则会自动判断该文件的创建时间,如果是十五天前的就会自动清除
END
注意事项