0
点赞
收藏
分享

微信扫一扫

nginx日志按照天进行分割


由于nginx的日志本身只是支持按照server_name或者大小进行划分,对于习惯了apache的按照一个网站每天一个日志的我来说是不可以接受的,于是从网上找了几个nginx按天分割的方法发现都是互相抄袭的,特别是里面有一个命令是kill -9 `cat nginx.pid`,需要杀掉nginx子进程,我觉得不靠谱。



我忽然想到我以前在做openstack的云存储开发时,对rsyslog的日志进行分割的方法,一用果然好用



原理是:



nginx日志按照天进行分割_nginx



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


    点击(此处)折叠或打开


    1. access_log /opt/nginx_logs/abc_www/access_log;


    点击(此处)折叠或打开



      1. mkdir /opt/nginx_logs/abc_www/log/


      点击(此处)折叠或打开


      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


      点击(此处)折叠或打开



        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 &


        nginx日志按照天进行分割_nginx_02




         



        -----------------------------方法二------------------------


        1. #!/bin/bash
        2. # 请将当前脚本的运行时间设置成 00:00
        3. # 这里是日志保存路径
        4. logs_path=”/home/www/logs/”
        5. #分割日志
        6. mkdir -p ${logs_path}$(date -d “yesterday” +”%Y”)/$(date -d “yesterday” +”%m”)/
        7. mv ${logs_path}access.log ${logs_path}$(date -d “yesterday” +”%Y”)/$(date -d “yesterday” +”%m”)/access_$(date -d “yesterday” +”%Y%m%d”).log
        8. mkdir -p ${logs_path}$(date -d “yesterday” +”%Y”)/$(date -d “yesterday” +”%m”)/
        9. mv ${logs_path}qanote.log ${logs_path}$(date -d “yesterday” +”%Y”)/$(date -d “yesterday” +”%m”)/qanote_$(date -d “yesterday” +”%Y%m%d”).log
        10. #重启nginx
        11. kill -USR1 `cat /var/run/nginx.pid`

        .配置crontab 每天凌晨00:00定时执行这个脚本

        crontab -e
        00 00 * * * /bin/bash /usr/local/nginx/sbin/cut_nginx_log.sh
        $cd /etc/init.d
        ./crond restart

        举报

        相关推荐

        0 条评论