nginx日志管理脚本

此脚本实现nginx日志文件按天自动切割,并且删除一个月前的日志
先上脚本:
 

Java代码 复制代码
  1. #!/bin/bash   
  2. cd /var/log/nginx/   
  3. mv  sendsadmin.access.log sendsadmin.access.$(date +%Y%m%d).log   
  4. mv  api.sends.cc.access.log api.sends.cc.access.$(date +%Y%m%d).log   
  5. mv  blog.sends.cc.access.log blog.sends.cc.access.$(date +%Y%m%d).log   
  6. mv  error.log error.$(date +%Y%m%d).log   
  7. sudo kill -USR1 `cat  /usr/local/web/nginx636/logs/nginx.pid`   
  8.   
  9. find /var/log/nginx/ -name "sendsadmin.access.*" -type f -ctime +30 -exec rm {} \; > /dev/null 2>&1  
  10. find /var/log/nginx/ -name "api.sends.cc.access.*" -type f -ctime +30 -exec rm {} \; > /dev/null 2>&1  
  11. find /var/log/nginx/ -name "blog.sends.cc.access.*" -type f -ctime +30 -exec rm {} \; > /dev/null 2>&1  
  12. find /var/log/nginx/ -name "error.*" -type f -ctime +30 -exec rm {} \; > /dev/null 2>&1  
#!/bin/bash
cd /var/log/nginx/
mv  sendsadmin.access.log sendsadmin.access.$(date +%Y%m%d).log
mv  api.sends.cc.access.log api.sends.cc.access.$(date +%Y%m%d).log
mv  blog.sends.cc.access.log blog.sends.cc.access.$(date +%Y%m%d).log
mv  error.log error.$(date +%Y%m%d).log
sudo kill -USR1 `cat  /usr/local/web/nginx636/logs/nginx.pid`
find /var/log/nginx/ -name "sendsadmin.access.*" -type f -ctime +30 -exec rm {} \; > /dev/null 2>&1
find /var/log/nginx/ -name "api.sends.cc.access.*" -type f -ctime +30 -exec rm {} \; > /dev/null 2>&1
find /var/log/nginx/ -name "blog.sends.cc.access.*" -type f -ctime +30 -exec rm {} \; > /dev/null 2>&1
find /var/log/nginx/ -name "error.*" -type f -ctime +30 -exec rm {} \; > /dev/null 2>&1



注解:
 

Java代码 复制代码
  1. mv  sendsadmin.access.log sendsadmin.access.$(date +%Y%m%d).log   
  2. #把日志文件sendsadmin.access.log改名为sendsadmin.access.(当天日期).log  
mv  sendsadmin.access.log sendsadmin.access.$(date +%Y%m%d).log
#把日志文件sendsadmin.access.log改名为sendsadmin.access.(当天日期).log



 

Java代码 复制代码
  1. sudo kill -USR1 `cat  /usr/local/web/nginx636/logs/nginx.pid`   
  2. #nginx重建日志文件  
sudo kill -USR1 `cat  /usr/local/web/nginx636/logs/nginx.pid`
#nginx重建日志文件



 

Java代码 复制代码
  1. find /var/log/nginx/ -name "sendsadmin.access.*" -type f -ctime +30 -exec rm {} \; > /dev/null 2>&1  
  2. #find -- 查找   
  3. #/var/log/nginx/ -- 查找日志目录   
  4. #-name "sendsadmin.access.*" -type f -- 找以"sendsadmin.access."开头的文件   
  5. #-ctime +30 -- 查找距离当日30天前文件   
  6. #-exec rm {} \; -- 找到后执行rm命令   
  7. #> /dev/null 2>&1 -- 输出重定向  
find /var/log/nginx/ -name "sendsadmin.access.*" -type f -ctime +30 -exec rm {} \; > /dev/null 2>&1
#find -- 查找
#/var/log/nginx/ -- 查找日志目录
#-name "sendsadmin.access.*" -type f -- 找以"sendsadmin.access."开头的文件
#-ctime +30 -- 查找距离当日30天前文件
#-exec rm {} \; -- 找到后执行rm命令
#> /dev/null 2>&1 -- 输出重定向



保存脚本到本地并把脚本加入crontab每天23:59运行
 

Java代码 复制代码
  1. sudo vi /etc/crontab   
  2. 加入以下:   
  3. 59 23   * * *   root    /bin/bash /usr/local/web/nginx636/conf/cutlogs.sh  

你可能感兴趣的:(nginx,职场,日志管理,休闲)