zoukankan      html  css  js  c++  java
  • 自定义日志轮转

    自定义日志轮转

    日志轮转的作用:防止业务日志写满磁盘

    自定义轮转Demo:

    vim /etc/logrotate.d/myrotate
    
    /dev/shm/* {
        daily
        missingok
        rotate 4
        su root root
        compress
        delaycompress
        notifempty
        create 0640 www-data root
        sharedscripts
        postrotate
            if [ -f /var/run/nginx.pid  ]; then
                kill -USR1 `cat /var/run/nginx.pid `
            fi
         endscript
    }
    
    

    ps:

    kill -USR1 `cat /var/run/nginx.pid `
    作用是让nginx平滑加载,不然nginx不会重新创建日志,导致日志异常
    

    参数解释:

    compress 					通过gzip 压缩转储以后的日志
    nocompress 					不做gzip压缩处理
    create mode owner group 	轮转时指定创建新文件的属性,如create 0777 nobody nobody
    nocreate 					不建立新的日志文件
    delaycompress 和compress 	一起使用时,转储的日志文件到下一次转储时才压缩
    nodelaycompress 			覆盖 delaycompress 选项,转储同时压缩。
    missingok 					如果日志丢失,不报错继续滚动下一个日志
    ifempty 					即使日志文件为空文件也做轮转,这个是logrotate的缺省选项。
    notifempty 					当日志文件为空时,不进行轮转
    mail address 				把转储的日志文件发送到指定的E-mail 地址
    olddir directory 			转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统
    noolddir 					转储后的日志文件和当前日志文件放在同一个目录下
    sharedscripts 				运行postrotate脚本,作用是在所有日志都轮转后统一执行一次脚本。如果没有配置这个,那么每个日志轮转后都会执行一次脚本
    prerotate 					在logrotate转储之前需要执行的指令,例如修改文件的属性等动作;必须独立成行
    postrotate 					在logrotate转储之后需要执行的指令,例如重新启动 (kill -HUP) 某个服务!必须独立成行
    daily 						指定转储周期为每天
    weekly 						指定转储周期为每周
    monthly 					指定转储周期为每月
    rotate count 				指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份
    dateext 					使用当期日期作为命名格式
    dateformat .%s 				配合dateext使用,紧跟在下一行出现,定义文件切割后的文件名,必须配合dateext使用,只支持 %Y %m %d %s 这四个参数
    size(或minsize) log-size 	当日志文件到达指定的大小时才转储,log-size能指定bytes(缺省)及KB (sizek)或MB(sizem).
    
    

    测试和使用

    日志轮转完成后先进行debug测试,可以在强制轮转一下,看配置是否生效

    /usr/sbin/logrotate -dv /etc/logrotate.d/myrotate
    /usr/sbin/logrotate -f /etc/logrotate.d/myrotate
    -d|--debug		#详细显示指令执行过程,便于排错或了解程序执行的情况
    -v|--verbose  	#显示指令执行过程
    -f|--force   	#强制轮转
    

    ps:

    如果日志没有定期轮转,检查logrotate的cron定时任务文件是否正常。/etc/cron.daily/logrotate

    在查看下cron进程是否存在 systemctl status cron

  • 相关阅读:
    内核驱动系列中断和定时器
    apue2 阅读笔记第四章
    apue2 阅读笔记 第五章
    apue2阅读笔记 第6.7章
    再试试windows7版得writer
    内核驱动系列内核调试方法
    apue2 阅读笔记第三章
    杂谈关于代码库
    know everything about something
    React的父子传值(父传子)
  • 原文地址:https://www.cnblogs.com/feng0919/p/15357880.html
Copyright © 2011-2022 走看看