利用logrotate 防止linux系统日志文件过大

最近服务器出了点小问题,日志文件不断地成倍地增大,但是貌似对系统运行没什么影响,只是这个日志文件不停地增大会导致系统空间爆炸,所以我这里用logrotate功能将日志文件转存并且在日志文件中滚动写入将转存的旧文件覆盖掉,下面会详细介绍:

1 logrotate配置文件

路径/etc/logrotate.d


我这里在这个目录下创建了messagelog这个配置文件来执行logrotate,在后面执行logrotate时会自动调用这个目录下的所有文件

2 messagelog配置文件


说明一下这个配置文件,这个配置文件是用于转存/var/log目录下的messages-20180205这个日志文件,size默认是KB,这里10000KB也就是10M,就是当该日志文件大小达到10MB的时候就会实行转存,rotate是转存的文件数量,如果是4就表示转存的文件数量最大为4,如果messages-20180205这个日志文件转存4个之后还是继续增大超过10MB再转存的时候就会在第一个转存的日志文件上面循环,依次迭代,总之转存的日志文件数量不会超过4个,这样就把日志文件的大小间接地限制了。

这里建议大家加上compress这个参数,也就是变成下面那样

/var/log/messages-20180205
{
        size 10000
        rotate 4
        copytruncate
        compress
}

compress对转存之后的日志文件进行压缩,这样就更小了,这里我没有加,因为我的日志文件本来就不是很大

3下面我写了一个for.sh脚本往这个文件里面循环写入,让他增大

[root@localhost /]# more for.sh
#!/bin/sh 
i=1
while [ $i -ge 0 ]; do
        echo "aaa" >> /var/log/messages-20180205
done

然后我在远程连接的窗口里面开始执行这个文件,让messages-20180205不断增大

4接着我又多开了远程连接的窗口,使用du -sh命令观察这个日志文件的大小变化


可以看到文件在不断增大

5然后我再开一个窗口,观察这个日志文件超过10MB之后就执行转存命令

/usr/sbin/logrotate /etc/logrotate.conf

6在回到/var/log目录下,查看转存的文件是否生成


可以看到,他会以日志文件加时间后缀名生成一个文件,如果你在配置Logrotate的时候加上了compress的话会生成一个gz结尾的压缩文件,查看这个转存文件大小,43MB,因为我是在日志文件增大到43M才开始转存的,所以这里会按照原来大小转存一个日志文件,如果你加了compress压缩,这个转存文件会小很多



注意!从上面转存的文件名以时间后缀生成可以发现,每天只能转存一个文件,所以大家在规划logrotate配置的size时要想好多大开始转存,如果发现日志文件增长得很快建议把size参数弄大点。

7上面只是我手工做实验模拟日志文件如何增长,并且手动转存,如果要自动转存,要转存日志文件的命令加入到crontab定时执行利民啊

最后可以把/usr/sbin/logrotate /etc/logrotate.conf这条命令加入到linux的crontab里面

*/5 * * * * /usr/sbin/logrotate /etc/logrotate.conf  

每隔5分钟检查日志文件是否大于10MB,大于10MB就会转存日志文件


我通过4日的观察,这里补上我的观察图



可以看到4月12号的文件被4月17号的文件自动覆盖,这样子就维持了日志文件为4个不变了


  • 5
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要按大小切割日志文件,可以使用 logrotate 工具来实现。logrotate 工具可以定期对指定的日志文件进行轮转,以便于管理和备份。 以下是按大小切割日志文件的步骤: 1. 安装 logrotate 工具,可以使用以下命令进行安装: ``` sudo apt-get install logrotate ``` 2. 创建一个 logrotate 配置文件,可以在 /etc/logrotate.d 目录下创建一个新的文件,例如 /etc/logrotate.d/myapp。在该文件中,可以配置需要轮转的日志文件、轮转周期、保存的备份数量等参数。例如: ``` /var/log/myapp.log { size 10M rotate 5 compress dateext create 0644 root root } ``` 上面的配置表示,对 /var/log/myapp.log 文件进行轮转,当文件大小达到 10M 时进行轮转,最多保存 5 个备份文件,使用 gzip 进行压缩,备份文件名添加日期后缀,新建备份文件的权限为 0644,属主为 root。 3. 手动执行 logrotate 来进行日志轮转,可以使用以下命令来进行手动轮转: ``` logrotate -f /etc/logrotate.d/myapp ``` 上面的命令表示,强制执行 /etc/logrotate.d/myapp 配置文件中定义的轮转操作。 4. 配置 logrotate 定时任务,定期执行轮转操作。可以编辑 /etc/crontab 文件,添加以下行: ``` 0 0 * * * root logrotate -f /etc/logrotate.d/myapp ``` 上面的配置表示,每天午夜 0 点执行 logrotate 命令来进行日志轮转。 注意:在配置 logrotate 时,需要根据实际情况进行配置,以免误删重要的日志信息。另外,需要按照一定的规则来命名备份文件,以便于管理和查找。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值