zoukankan      html  css  js  c++  java
  • Nginx日志切割

    Nginx访问日志切割的两种方法:

    1.mv命令+shell脚本

    2.利用logrotate日志文件管理工具

    一、mv + shell 脚本命令实现日志切割

    #!/bin/bash
    #auto
    mv nginx log shell #by author 941268778 S_LOG=/usr/local/nginx/logs/access.log D_LOG=/data/backup/`date +%Y%m%d` echo -e "33[32mPlease wait start cut shell scripts...33[1m" sleep 2 if [ ! -d $D_LOG ];then mkdir -p $D_LOG fi mv $S_LOG $D_LOG kill -USR1 `cat /usr/local/nginx/logs/nginx.pid` echo "-------------------------------------------" echo "The Nginx log Cutting Successfully!" echo "You can access backup nginx log $D_LOG/access.log files."

    #配置计划任务

    #crontab /var/spool/cron/root文件中添加如下代码,每天凌晨自动切割日志:

    0  0  *  *  *  /bin/sh  /data/sh/auto_nginx_log.sh >>/tmp/nginx_cut.log 2>&1

     

    知识点补充:

    官方文档出处:http://nginx.org/en/docs/control.html

    Nginx信号控制使用的几个选项:

    二、安装logrotate工具

    yum install logrotate -y

    安装完成后,自动在/etc/cron.daily/下生成个 logrotate 可执行的脚本文件,此脚本每天都会执行一次。

    配置logrotate:

    #在 /etc/logrotate.d/ 目录下新建一个 nginx 的文件
    vim /etc/logrotate.d/nginx #########以下为文件配置内容##############
     

    /var/log/nginx/*.log {
       daily
       rotate 100
       missingok
       compress
       delaycompress
       notifempty
       create 644 nginx nginx
       postrotate
         if [ -f /app/nginx/logs/nginx.pid ]; then
           kill -USR1 `cat /app/nginx/logs/nginx.pid`
         fi
       endscript
    }

    我们也可以先手 手动执行一下切割试试看看效果

    logrotate -f /etc/logrotate.d/nginx

     logrotate 配置项详解

    logrotate 的默认配置文件是 /etc/logrotate.conf。主要参数:
    daily–>指定转储周期为每天
    
    weekly–>指定转储周期为每周
    
    monthly–>指定转储周期为每月
    
    dateext–>在文件末尾添加当前日期
    
    compress–>通过 gzip 压缩转储以后的日志
    
    nocompress–>不需要压缩时,用这个参数
    
    copytruncate–>先把日志内容复制到旧日志文件后才清除日志文件内容,可以保证日志记录的连续性
    
    nocopytruncate–>备份日志文件但是不截断
    
    create mode owner group–>转储文件,使用指定的文件模式创建新的日志文件
    
    nocreate–>不建立新的日志文件
    
    delaycompress 和 compress –>一起使用时,转储的日志文件到下一次转储时才压缩
    
    nodelaycompress–>覆盖 delaycompress 选项,转储同时压缩。
    
    errors address–>专储时的错误信息发送到指定的 Email 地址
    
    ifempty–>即使是空文件也转储,这个是 logrotate 的缺省选项。
    
    notifempty–>如果是空文件的话,不转储
    
    mail address–>把转储的日志文件发送到指定的 E-mail 地址
    
    nomail–>转储时不发送日志文件
    
    olddir directory–>转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统
    
    noolddir–>转储后的日志文件和当前日志文件放在同一个目录下
    
    rotate count–>指定日志文件删除之前转储的次数,0 指没有备份,5 指保留 5 个备份
    
    tabootext [+] list 让 logrotate –> 不转储指定扩展名的文件,缺省的扩展名是:.rpm-orig, .rpmsave, v, 和 ~
    
    size–> size 当日志文件到达指定的大小时才转储,Size 可以指定 bytes (缺省)以及 KB (sizek)或者 MB (sizem).
    
    prerotate/endscript –>在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行
    
    postrotate/endscript –>在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行
  • 相关阅读:
    Git修改注释
    数组和切片的区别
    SpringBoot启动报:Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled.
    eclipse中web.xml报:The content of element type "web-app" must match "(icon?,display- name?,
    eclipse错误: 在类xxx中找不到 main 方法, 请将 main 方法定义为: public static void main(String[] args) 否则 JavaFX 应用程序类必须扩展javafx.application.Application
    idea Cannot resolve method ‘setAttribute(java.lang.String, java.lang.String)/不能使用pageContext.setAttribute()
    解决Nginx启动报nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
    数据仓库开发规范
    详解会话技术cookie、session和token
    Requests爬虫包及解析工具 xpath、正则、Beautiful Soup
  • 原文地址:https://www.cnblogs.com/yds941268778/p/13819625.html
Copyright © 2011-2022 走看看