ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、视频、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
# :-: 日志轮转 | 适用范围 | 适用版本 | 人员 | 发布时间 | 文档版本 |备注 | | --- | --- | --- | --- | --- |--- | | 服务器操作系统 | V10-SP1-0518-arm64 | 王承林 |2022.3.2| V1.0|发布| | 服务器操作系统 | V10-SP1-0518-arm64 | 张志勇 |2022.3.2| V1.1|模板调整| ### 经测试,该方案有效可行 ***** 查看/etc/logrotate.d/rsyslog 如果存在关于message的描述直接在原文件上面修改,记得修改之前进行备份 #注意如果/etc/logrotate.d/rsyslog 没有message相关内容需要通过 `egrep -ri message /etc/logrotate.d/ ` 来查看mesage默认轮转配置所在,然后进行下面操作,注意文件名称 `cp /etc/logrotate.d/rsyslog /etc/logrotate.d/rsyslog.bak` `vim /etc/logrotate.d/rsyslog` 修改message为以下下配置: ``` /var/log/messages { rotate 53 missingok notifempty compress weekly sharedscripts postrotate /usr/bin/killall -HUP rsyslogd ln /var/log/messages /var/log/syslog -f endscript } ``` 最后重启服务: `systemctl restart rsyslog` 逐行分析: ``` rotate 53 #日志旧文件最多保存53份,一周一份,则正好一年 missingok #忽略轮转时候报错notifempty #源文件不变weekly # 一 周 一 次 轮 转 compress #压缩格式保存旧文件 create 0644 root root #创建新的,权限和拥有人拥有组 sharedscripts #运行postrotate脚本,作用是在所有日志都轮转后统一执行一次脚本。如果没有配置这个,那么每个日志轮转后都会执行一次脚本 postrotate /usr/bin/killall -HUP rsyslogd ln /var/log/messages /var/log/syslog -f endscript #执行上述两条命令, 这两条命令more保存不要变动 ``` 修 改 完 后 强 制 轮 转 一 次: `logrotate -f /etc/logrotate.conf` #注意:日志轮转可以修改日志旧文件保存路径即为 olddir $dir ,但是和原先的日志文件应为同一个文件系统; #注意:保存的文件需要经常查看文件系统剩余空间,因为保存一年,可能把文件系统撑满导致系统异常。 其他参数补充: ``` weekly //默认每一周执行一次rotate轮转工作 rotate 4 //保留多少个日志文件(轮转几次).默认保留四个.就是指定日志文件删除之前轮转的次数,0 指没有备份 create //自动创建新的日志文件,新的日志文件具有和原来的文件相同的权限;因为日志被改名,因此要创建一个新的来继续存储之前的日志 dateext //这个参数很重要!就是切割后的日志文件以当前日期为格式结尾,如xxx.log- 20131216这样,如果注释掉,切割出来是按数字递增,即前面说的 xxx.log-1这种格式 compress //是否通过gzip压缩转储以后的日志文件,如xxx.log-20131216.gz ;如果不需要压缩,注释掉就行weekly //默认每一周执行一次rotate轮转工作 rotate 4 //保留多少个日志文件(轮转几次).默认保留四个.就是指定日志文件删除之前轮转的次数,0 指没有备份 create //自动创建新的日志文件,新的日志文件具有和原来的文件相同的权限;因为日志被改名,因此要创建一个新的来继续存储之前的日志 dateext //这个参数很重要!就是切割后的日志文件以当前日期为格式结尾,如xxx.log- 20131216这样,如果注释掉,切割出来是按数字递增,即前面说的 xxx.log-1这种格式 compress //是否通过gzip压缩转储以后的日志文件,如xxx.log-20131216.gz ;如果不需要压缩,注释掉就行 nocompress 不做gzip压缩处理 copytruncate 用于还在打开中的日志文件,把当前日志备份并截断; 是先拷贝再清空的方式,拷贝和清空之间有一个时间差,可能会丢失部分日志数据。 nocopytruncate 备份日志文件不过不截断 create mode owner group 轮转时指定创建新文件的属性,如create 0777 nobody nobody nocreate 不建立新的日志文件 delaycompress 和compress 一起使用时,转储的日志文件到下一次转储时才压缩 nodelaycompress 覆盖 delaycompress 选项,转储同时压缩。 missingok 如果日志丢失,不报错继续滚动下一个日志 errors address 专储时的错误信息发送到指定的Email 地址 ifempty 即使日志文件为空文件也做轮转,这个是logrotate的缺省选项。 notifempty 当日志文件为空时,不进行轮转 mail address 把转储的日志文件发送到指定的E-mail 地址 nomail 转储时不发送日志文件 olddir directory 转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统 noolddir 转储后的日志文件和当前日志文件放在同一个目录下sharedscripts 运行postrotate脚本,作用是在所有日志都轮转后统一执行一次脚本。如果没有配置这个,那么每个日志轮转后都会执行一次脚本 prerotate 在logrotate转储之前需要执行的指令,例如修改文件的属性等动作;必须独立成行 postrotate 在logrotate转储之后需要执行的指令,例如重新启动 (kill -HUP) 某个服务!必须独立成行 daily 指定转储周期为每天 weekly 指定转储周期为每周 monthly 指定转储周期为每月 rotate count 指定日志文件删除之前转储的次数,0 指没有备份,5 指 保留5 个备份 dateext 使用当期日期作为命名格式 dateformat . 配合dateext使用,紧跟在下一行出现,定义文件切割后的文 件名,必须配合dateext使用,只支持 %Y %m %d %s 这四个参数 size(或minsize) log-size 当日志文件到达指定的大小时才转储,log-size能指定bytes(缺省)及KB (sizek)或MB(sizem). 当日志文件 >= log-size 的时候就转储。size = 5 或 size 5 (>= 5 个字节就转储) size = 100k 或 size 100k size = 100M 或 size 100M ```