我发现很多人的服务器上都运行着一些诸如每天切分Nginx日志之类的CRON脚本,大家似乎遗忘了Logrotate,争相发明自己的轮子,这真是让人沮丧啊!就好比明明身边躺着现成的性感美女,大家却忙着自娱自乐,罪过!

Logrotate的介绍

logrotate 程序是一个日志文件管理工具。用来把旧的日志文件删除,并创建新的日志文件,我们把它叫做“转储”。我们可以根据日志文件的大小,也可以根据其天数来转储,这个过程一般通过 cron 程序来执行。
logrotate 程序还可以用于压缩日志文件,以及发送日志到指定的E-mail 。
显而易见,Logrotate是基于CRON来运行的,其脚本是「/etc/cron.daily/logrotate」:
  1. [caoxiaojian@web1 etc]$ cat /etc/cron.daily/logrotate
  2. #!/bin/sh
  3. /usr/sbin/logrotate /etc/logrotate.conf >/dev/null 2>&1
  4. EXITVALUE=$?
  5. if [ $EXITVALUE != 0 ]; then
  6. /usr/bin/logger -t logrotate "ALERT exited abnormally with [$EXITVALUE]"
  7. fi
  8. exit 0
实际运行时,Logrotate会调用配置文件「/etc/logrotate.conf」:
  1. [caoxiaojian@web1 etc]$ cat /etc/logrotate.conf
  2. # see "man logrotate" for details
  3. # rotate log files weekly
  4. weekly
  5. # keep 4 weeks worth of backlogs
  6. rotate 4
  7. # create new (empty) log files after rotating old ones
  8. create
  9. # use date as a suffix of the rotated file
  10. dateext
  11. # uncomment this if you want your log files compressed
  12. #compress
  13. # RPM packages drop log rotation information into this directory
  14. include /etc/logrotate.d
  15. # no packages own wtmp and btmp -- we'll rotate them here
  16. /var/log/wtmp {
  17. monthly
  18. create 0664 root utmp
  19. minsize 1M
  20. rotate 1
  21. }
  22. /var/log/btmp {
  23. missingok
  24. monthly
  25. create 0600 root utmp
  26. rotate 1
  27. }
  28. # system-specific logs may be also be configured here.
这里的设置可以理解为Logrotate的缺省值,当然了,可以我们在「/etc/logrotate.d」目录里放置自己的配置文件,用来覆盖Logrotate的缺省值。

Logrotate的演示

按天保存一周的Nginx日志压缩文件,配置路径为:/etc/logrotate.d,创建一个nginx的文件
  1. /usr/local/nginx/logs/*.log {
  2. daily
  3. dateext
  4. compress
  5. rotate 7
  6. sharedscripts
  7. postrotate
  8. kill -USR1 `cat /var/run/nginx.pid`
  9. endscript
  10. }
如果你等不及CRON,可以通过如下命令来手动执行:
  1. [caoxiaojian@web1 etc]$ logrotate -f /etc/logrotate.d/nginx
当然,正式执行前最好通过Debug选项来验证一下,这对调试也很重要:
  1. [caoxiaojian@web1 etc]$ logrotate -d -f /etc/logrotate.d/nginx

参数 功能

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 转储后的日志文件和当前日志文件放在同一个目录下
 
prerotate/endscript 在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行
 
postrotate/endscript 在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行
 
daily 指定转储周期为每天
 
weekly 指定转储周期为每周
 
monthly 指定转储周期为每月
 
rotate count 指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份
 
tabootext [+] list 让logrotate 不转储指定扩展名的文件,缺省的扩展名是:.rpm-orig, .rpmsave, v, 和 ~
 
size size 当日志文件到达指定的大小时才转储,Size 可以指定 bytes (缺省)以及KB (sizek)或者MB (sizem).

Logrotate的疑问

问题:sharedscripts的作用是什么?

大家可能注意到了,我在前面Nginx的例子里声明日志文件的时候用了星号通配符,也就是说这里可能涉及多个日志文件,比如:access.log和error.log。说到这里大家或许就明白了,sharedscripts的作用是在所有的日志文件都轮转完毕后统一执行一次脚本。如果没有配置这条指令,那么每个日志文件轮转完毕后都会执行一次脚本。

官方配置解析











Logrotate还有谁记得它??的更多相关文章

  1. [转] 被遗忘的Logrotate

    FROM : http://huoding.com/2013/04/21/246 我发现很多人的服务器上都运行着一些诸如每天切分Nginx日志之类的CRON脚本,大家似乎遗忘了Logrotate,争相 ...

  2. 被遗忘的 Logrotate

    转自: http://huoding.com/2013/04/21/246 被遗忘的 Logrotate 发表于 2013-04-21 我发现很多人的服务器上都运行着一些诸如每天切分 Nginx 日志 ...

  3. 利用logrotate工具对catalina.out进行日志分割实战

    logrotate是linux自带的日志分割工具,如果没有可以用yum安装 yum -y install logrotate 要配置日志分割定时任务,需要在/etc/logrotate.d/下创建一个 ...

  4. QT,静态变量要记得初始化

    //DbUtil.h #ifndef DBUTIL_H #define DBUTIL_H using namespace std; QString md5Encode(QString passwd); ...

  5. 使用logrotate分割Tomcat的catalina日志

    切割catalian日志的方式有很多种,比如shell脚本的.cronolog或者通过配置log4j等等这些都可以实现.但今天我要介绍是使用logrotate来按日期生成日志. 原文是一个外国博主的文 ...

  6. c#静态构造函数 与 构造函数 你是否还记得?

    构造函数这个概念,在我们刚开始学习编程语言的时候,就被老师一遍一遍的教着.亲,现在你还记得静态构造函数的适用场景吗?如果没有,那么我们一起来复习一下吧. 静态构造函数是在构造函数方法前面添加了stat ...

  7. rsyslog及logrotate小结

    [root@node1 logrotate.d]# ls dracut haproxy httpd mcelog nginx ppp psacct syslog yum   yum install n ...

  8. 记得初学JS时候练个九九乘法表都写的要死要活

    还记得当初刚接触JS时候,看到视频中老师写了个九九乘法表,觉得好神奇,可是自己在下面动手写了半天还是有各种问题,甚是懊恼啊.今又看到园子里有关于乘法表的博文,出于对过去的不舍与缅怀,遂重写一遍. &l ...

  9. logrotate

    logrotate程序是一个日志文件管理工具.用于分割日志文件,删除旧的日志文件,并创建新的日志文件,起到"转储"作用.可以节省磁盘空间. logrotate命令格式:logrot ...

随机推荐

  1. sso(single sign on)介绍

    1. 浏览器 > 2. 系统A(www.a.com) > 3. 系统B(www.b.com) > 4. 认证中心(www.sso.com) #### ** (1)首次访问** > ...

  2. intellIJ IDEA配置maven相关问题记录

    IntellIJ IDEA 配置 Maven 以及 修改 默认 Repository 参考:https://www.cnblogs.com/phpdragon/p/7216626.html non-m ...

  3. 由 Session 和 Cookie 的区别说起

    Session 和 Cookie 有什么区别? 最近面试被问到这个问题,和面试官一番讨论了解到面试官心里的答案后,我不太满意. 面对上面的问题,如果是刚毕业时的我,一定会毫不犹豫说出 Cookie 是 ...

  4. Zabbix实战-简易教程--WEB类--Nginx

    一.开启Nginx status状态 1.在默认主机里面加上location添加ngx_status 如下操作: server { listen 127.0.0.1:8080; server_name ...

  5. 5 行 Python 代码调用电脑摄像头

    前提: 确保 python 中安装了 opencv-python 模块.如果没有安装,可以参考:https://pypi.org/project/opencv-python/ 进行安装.话不多少,直接 ...

  6. awk高级进阶

    第1章 awk数组练习题 1.1 文件内容(仅第一行) [root@znix test]# head -1 secure-20161219 access.log ==> secure-20161 ...

  7. IIS 配置网站

    IIS 配置网站最常见的问题 1 文件夹权限问题 (C盘 windows下temp文件夹权限问题)2 版本问题 (框架版本问题如4.0 在2.0下运行,4.5在4.0下运行) 3如果是局域网,考虑动态 ...

  8. 从零搭建HBase集群

    本文从零开始搭建大数据集群,涉及Linux集群安装搭建,Hadoop集群搭建,HBase集群搭建,Java接口封装,对接Java的C#类库封装 Linux集群搭建与配置 Hadoop集群搭建与配置 H ...

  9. Python学习之路:一天搞定基础部分

    ~代表省略的内容,如变量名.字符串等等 1.Pyhton中比较特别的运算: **:代表指数运算,例如2**3 = 8 //:代表整除运算,这一点和Java不同 2.Python的注释: #:单行注释 ...

  10. halcon二 图像校正

    1.get_image_size(Image : : : Width, Height) 返回图像的尺寸. 2.parameters_image_to_world_plane_centered (Cam ...