1:日志堆积导致磁盘爆满
这是服务器基本崩溃后,临时清理了磁盘后紧急恢复的状态
2:紧急查询磁盘崩溃的原因,无非是日志
[root@iZbp1f0xuq9rc41s6gdvfyZ ~]# cd /
[root@iZbp1f0xuq9rc41s6gdvfyZ /]# find . -type f -size +200M
3:定时清理Nginx日志
[root@iZbp1f0xuq9rc41s6gdvfyZ logs]# vi nginxLogDelete.sh
#!/bin/bash
#设置Nginx日志的文件位置
LOGS_PATH=/usr/local/nginx/logs
#设置保留时间 单位(天)
SAVE_TIME=30
#执行最终的命令
#查找 修改日志在30天前的同时以log结尾的文件然后删除
#如果没有-name选项过30之后脚本会被删除掉
find ${LOGS_PATH}/ -mtime +${SAVE_TIME} -name \*.log |xargs rm -rf {}
4:nginx日志切割
[root@iZbp1f0xuq9rc41s6gdvfyZ logs]# vi nginxLogRotate.sh
#!/bin/bash
#设置Nginx日志的文件位置
LOGS_PATH=/usr/local/nginx/logs
## 获取当天日期,用于日志文件名上
YESTERDAY=$(date -d "yesterday" +%Y-%m-%d)
## 移动access.log日志,并修改命名
mv ${LOGS_PATH}/access.log ${LOGS_PATH}/access_${YESTERDAY}.log
## 移动error.log日志,并修改命名
mv ${LOGS_PATH}/error.log ${LOGS_PATH}/error_${YESTERDAY}.log
## 向 Nginx 主进程发送 USR1 信号。USR1 信号是重新打开日志文件
kill -USR1 $(cat /usr/local/nginx/logs/nginx.pid)
5:配置成定时任务
[root@iZbp1f0xuq9rc41s6gdvfyZ logs]# crontab -e
#每天23点50分执行 /usr/local/nginx/logs/nginxLogRotate.sh脚本
50 23 * * * bash /usr/local/nginx/logs/nginxLogRotate.sh
#每天清理30天前的Nginx日志
55 23 * * * /usr/local/nginx/logs/nginxLogDelete.sh
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/160789.html