打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
nginx日志按照天进行分割
    由于nginx的日志本身只是支持按照server_name或者大小进行划分,对于习惯了apache的按照一个网站每天一个日志的我来说是不可以接受的,于是从网上找了几个nginx按天分割的方法发现都是互相抄袭的,特别是里面有一个命令是kill -9 `cat nginx.pid`,需要杀掉nginx子进程,我觉得不靠谱。
我忽然想到我以前在做openstack的云存储开发时,对rsyslog的日志进行分割的方法,一用果然好用
原理是:
1.从一台已经安装好apache的机器上的apache bin目录下把rotatelogs拷贝到本机的/opt/nginx_logs下

点击(此处)折叠或打开

  1. mkdir -p /opt/nginx_logs
  2. cp rotatelogs /opt/nginx_logs/
  3. chmod +x /opt/nginx_logs/rotatelogs
2.创建有名管道

点击(此处)折叠或打开

  1. mkdir /opt/nginx_logs/abc_www/
  2. mkfifo /opt/nginx_logs/abc_www/access_log
3.在nginx配置文件server中加上

点击(此处)折叠或打开

  1. access_log /opt/nginx_logs/abc_www/access_log;
4.创建日志目录

点击(此处)折叠或打开

  1. mkdir /opt/nginx_logs/abc_www/log/
5.创建日志分割脚本

点击(此处)折叠或打开

  1. [root@localhost nginx_logs]# cat /opt/nginx_logs/abc_www/rotate.sh
  2. baselogdir=/opt/nginx_logs/abc_www
  3. rotatelogs=/opt/nginx_logs/rotatelogs
  4. while [ 1 ]
  5. do
  6. echo `date +"%F %T"`" rotatelogs access start"
  7. $rotatelogs $baselogdir/log/access_%Y%m%d.log 86400 480 < $baselogdir/access_log
  8. echo `date +"%F %T"`" rotatelogs access stop"
  9. sleep 1;
  10. done
6.创建启动日志分割脚本

点击(此处)折叠或打开

  1. [root@localhost nginx_logs]# cat /opt/nginx_logs/abc_www/run.sh
  2. sh /opt/nginx_logs/abc_www/rotate.sh >> /opt/nginx_logs/abc_www/log/access-rotate.log 2>&1 &
7.最终效果
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
使用awstats分析Nginx的访问日志
apache两种日志格式同时生成
OHaHa‘s學習心得 | rotatelogs - 讓Apache 輪迴產生log 而不用中斷服務
rotatelog日志切割
Apache虚拟主机设置
Apache 2.2.3 log日志用rotatelogs实现按天记录
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服