logrotate执行定时执行不生效,踩坑

logrotate是系统自带的日志回滚模块,默认情况配置情况下,没发现什么问题。

但是在现场应用环境中,一般会根据自己的需求进行参数修改。以syslog为例记录此次踩坑过程。

syslog的logrotate配置如下:

/var/log/cron
/var/log/maillog
/var/log/messages
/var/log/secure
/var/log/boot.log
/var/log/spooler
{
    su root root
    copytruncate
    rotate 30
    size 64M
    compress
    missingok
    sharedscripts
    postrotate
    /bin/kill -HUP `cat /var/run/syslogd.pid 2> /dev/null` 2> /dev/null || true
    endscript
}

crontab配置如下:

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/

# For details see man 4 crontabs
# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name command to be executed
*/30 *  *  *  * root /usr/sbin/logrotate /etc/logrotate.d/syslog

为了节省日志占用存储空间,所以添加了compress参数,让日志回滚的时候自动压缩,也就是这个参数踩坑了。

正常情况回滚压缩都没有问题,但是作为生产环境,偶尔系统会出现故障,要排查某个历史时间点的系统状况,需要解压之前日志,很多时候会直接在/var/log/下直接解压然后查看日志内容。比如messages日志,解压messages.1.gz解压之后获得messages.1,如果查完问题没有把message.1恢复为原来压缩状态,达到回滚条件之后,下次压缩就会报失败。

/usr/sbin/logrotate /etc/logrotate.d/syslog
error: error creating output file /var/log/messages.1: File exists

 在定时任务中执行,不会有报错输出,messages日志也没有记录,这个地方目前我还没找到合适的logrotate参数进行配置来解决这个问题,如果有其他解决方案,请评论区告诉我一下。

  • 临时的解决方案如下:

在定时任务中添加一个动作,每次执行回滚任务之前,把所有要回滚的日志文件检查一遍,如果有某个日志文件的*.1存在,就压缩为原来的状态,为了尽量保存日志的完整,把其他解压的后续文件也都压缩为原来的状态*.[序号].gz,保持日志文件的连续性

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Logrotate是一个Linux系统工具,用于定期管理日志文件,将其归档、压缩并删除过期的日志,以节省磁盘空间和优化性能。以下是设置logrotate定时执行的基本步骤: 1. **安装logrotate(如有必要)**: 在大多数Linux发行版中,logrotate已经预装,但如果没有,你可以使用包管理器安装,如在Ubuntu/Debian上运行 `sudo apt-get install logrotate`。 2. **编辑logrotate配置文件**: Logrotate的配置文件通常位于 `/etc/logrotate.d` 目录下,每个要管理的日志文件或目录对应一个配置文件。例如,你可能有一个名为 `myapp.log` 的文件,可以创建一个名为 `myapp.log` 的新文件,内容如下: ```bash /var/log/myapp.log { daily rotate 7 compress delaycompress missingok notifempty } ``` 这里,`daily` 指定每天执行,`rotate 7` 表示保留7天的日志副本,`compress` 后续的日志会被压缩,`delaycompress` 保证当天的日志被处理前不被压缩,`missingok` 如果日志文件不存在不会报错,`notifempty` 只有当文件为空时才进行删除操作。 3. **配置cron定时任务**: 使用crontab来设置logrotate定时执行。打开crontab编辑器,输入命令: ```bash crontab -e ``` 在文件底部添加一行,例如每小时执行一次: ```bash */1 * * * * /usr/sbin/logrotate /etc/logrotate.conf ``` 或者按每天的特定时执行,如每天凌晨1点: ```bash 0 1 * * * /usr/sbin/logrotate /etc/logrotate.conf ``` 4. **重启或测试logrotate服务**: 修改配置后,你需要重启logrotate服务或者运行一次手动检查来应用新的设置: ```bash sudo service logrotate restart /usr/sbin/logrotate /etc/logrotate.conf ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值