设为首页 收藏本站
查看: 578|回复: 0

[经验分享] log日志轮转--logrotate

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-10-14 08:45:52 | 显示全部楼层 |阅读模式
服务器上的日志包括系统日志和服务日志每天都会产生n多log,好多人会自己写脚本来进行日志的切割、压缩等,而忽略了系统自带的服务--logrotate。
  简介
  logrotate是个十分有用的工具,它可以自动对日志进行截断(或轮循)、压缩以及删除旧的日志文件。它是基于CRON来运行的,其脚本是「/etc/cron.daily/logrotate」。主流Linux发行版上都默认安装有logrotate包,这也是我选择用他的主要原因。

  使用
  实际运行时,Logrotate会调用配置文件「/etc/logrotate.conf」:
也可以在「/etc/logrotate.d」目录里放置自己的配置文件,用来覆盖Logrotate的缺省值。
下面是一个切割rabbitmq日志的例子:
1
2
3
4
5
6
7
8
9
10
11
12
13
/var/log/rabbitmq/*.log {
        weekly
        missingok
        rotate 20
        compress
        delaycompress
        notifempty
        dateext
        copytruncat
        sharedscripts      
        postrotate
            /etc/init.d/rabbitmq-server rotate-logs > /dev/null
        endscript



logrotate参数说明:
  • daily — 每日旋转日志文件。
    weekly — 每周旋转日志文件。
    monthly — 每月旋转日志文件。
  • compress — 用gzip压缩旋转的日志文件。
  • size size — 在日志文件达到一定大小时开始旋转。大小是以bytes (默认), kilobytes (sizek)或megabytes (sizem)计算。

  • nocompress — 在不需要压缩旋转日志文件的情况下使用。
  • delaycompress — 在使用压缩选择时,旋转文件不会在下一个循环开始时被压缩。
  • copytruncate — 用于还在打开中的日志文件,把当前日志备份并截。复制当前的日志文件,并置空当前文件。

  • nocopytruncate — 把日志文件复制进备份,但该开放文件不会被裁剪。
  • dateext - 用时间格式表示日志,轮换的日志后缀为-YYYYMMDD格式
  • rotate count — 在删除前旋转文件的特定次数。如果计数为零,就意味着没有副本保留。而5则意味着保留5个副本。

  • create mode owner group — 旋转日志文件并创建允许特定组合用户的新文件。缺省是使用与原始文件一样的模式,组合用户。
  • missiongok - 如果文件找不到的话不会报错,直接跳过
  • nocreate — 可以防止产生新日志文件。
  • nodelaycompress –    日志文件会在循环过程中被压缩。
  • errors address — 将logrotate错误邮件发送到某个地址。
  • ifempty — 即使在空文件时也要旋转。这是Logrotate的缺省项。
  • notifempty — 空文件不旋转。
  • mail address — 这个邮件日志文件是循环到一个地址,因此能有效从系统中清楚。

  • nomail - 在邮件日志循环时,副本不邮寄。
  • olddir directory — 这个选项会将循环日志文件保持在特定目录。该目录必需与现有日志文件在同一文件系统。

  • noolddir — 循环的日志文件与现有文件处于相同目录。
  • prerotate/endscript - 在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行
  • postrotate/endscript - 在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行

其他参数可自行通过man logrotate查看帮助。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-285734-1-1.html 上篇帖子: Ubuntu下登录界面允许选择root账号登录和禁用guest用户登录 下篇帖子: CentOS7.2搭建LAMP+xcache环境
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表