博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
nginx日志切割和日志清理
阅读量:2338 次
发布时间:2019-05-10

本文共 1306 字,大约阅读时间需要 4 分钟。

 

##########################日志切割################################

1、上传脚本到/usr/local/nginx/logs/下 
2、并附执行权限
chmod +x cut_nginx_log.sh

3、编写定时任务  每天0点0分 执行cut_nginx_log.sh脚本
crontab -e
0 0 * * *  root /usr/local/nginx/logs/cut_nginx_log.sh
或者 
vim /etc/crontab
0 0 * * *  root /usr/local/nginx/logs/cut_nginx_log.sh

 

cat   cut_nginx_log.sh

#!/bin/bash

#日志存放路径
LOGS_PATH=/usr/local/nginx/logs
#获取昨天的时间
YESTERDAY=$(date -d "yesterday" +%Y-%m-%d)
#nginx的PID路径
NGINX_PID=/usr/local/nginx/logs/nginx.pid
#把当前的access.log/error.log重命名为access.yesterday.log/error.yesterday.log
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 $(cat ${NGINX_PID})

###########################日志清理#################################

1、上传脚本到/usr/local/nginx/logs/下 
2、并附执行权限
chmod +x rm_nginx_logfile.sh

3、编写定时任务  每天0点0分 rm_nginx_logfile.sh脚本

crontab -e
0 0 * * *  root /usr/local/nginx/logs/rm_nginx_logfile.sh
或者 
vim /etc/crontab
0 0 * * *  root /usr/local/nginx/logs/rm_nginx_logfile.sh

 

 

 

cat   rm_nginx_logfile.sh

 

#!/bin/bash

#日志所在路径
LOGS_PATH=/usr/local/nginx/logs
#设置保留时间  单位(天)
SAVE_TIME=30
#执行最终的命令 
#查找 修改日志在30天前的同时以log结尾的文件然后删除
#如果没有-name选项过30之后脚本会被删除掉
find ${LOGS_PATH}/ -mtime +${SAVE_TIME} -name \*.log |xargs rm -rf {}
 

转载地址:http://cugpb.baihongyu.com/

你可能感兴趣的文章
常用算法总结
查看>>
数据库连接池
查看>>
JAVA Webservice
查看>>
Hibernate自动生成实体类
查看>>
Java Memcached
查看>>
JAVA WebSpider
查看>>
XML自动建表/存库
查看>>
Java实现Web服务器
查看>>
C# readonly与const的区别
查看>>
VS2010/MFC编程入门之三十一(常用控件:树形控件Tree Control 下)
查看>>
CMarkup概述
查看>>
VC解析XML--使用CMarkup类解析XML
查看>>
VC最简版图片打印程序
查看>>
dll lib exe
查看>>
dll 和lib的调用方式
查看>>
vc下DLL/lib的调用
查看>>
VC 6 MFC 美化界面方法和技巧
查看>>
-stdcall详解
查看>>
VS2010 编码问题 不能将参数 1 从“ATL::CStringT<BaseType,StringTraits>”转换为“const char *”
查看>>
MFC子窗口和父窗口(SetParent,SetOwner)
查看>>