Linux定时任务-自动清理log日志文件,附案例详解。

一、为什么要定时清理log文件?

实际工作中,我们部署到服务器的应用可能随时在写入日志,有的应用一天产生的日志就较大,但是磁盘空间有限,所以磁盘常常很快就处于用完状态,并由此产生一些问题,比如服务器上应用可能挂掉,影响生产。

二、如何清理log文件?

估摸着时间就去看看磁盘删删log文件??显然不科学,,这里记录一个高效的方法:编写Linux定时任务脚本,自动清理log日志文件。

1、创建shell脚本文件并赋予执行权限:

[root@aigoV_66 ~]# touch auto_del_sjjk_log.sh    //创建shell文件
[root@aigoV_66 ~]# chmod +x auto_del_sjjk_log.sh   //赋予文件执行权限
关于 chmod +x 命令 :

    Linux下不同的文件类型,其文件名有不同的颜色:
    蓝色表示目录,绿色表示可执行文件,红色表示压缩文件,浅蓝色表示链接文件,灰色表示其它文件。
    新建的shell文件只是一个灰色的普通文件。
    执行 chmod +x 命令,此时文件变成了绿色,有了可执行权限。
    若再使用 chmod -x 命令,就去除了执行权限。

2、编辑刚创建的shell脚本文件,写入删除命令:

[root@aigoV_66 ~]# vi auto_del_sjjk_log.sh 

#!/bin/sh

find git_workspace/xny/数据接口/target/log/ -mtime +2 -name "*.log" -exec rm -rf {} \;
~                                                                                                                                       
~                                                                                                                                                                                                                                                                                                                                                                                                              
~                                                                                                                                       
-- INSERT --
关于上面命令:

    vi xx.sh :
    编辑xx.sh 脚本文件。
    进入编辑区后,按i键开始编辑,编辑完按Esc键,然后键入冒号:,再输入wq,回车保存退出。

    删除命令部分:
    find    查找命令,查找指定文件。
    git_workspace/xny/数据接口/target/log/    需要清理的文件的目录位置。
    -mtime    标准语句写法
    +2    数字指代天数,即删除2天以前的      -name "*.log.*" -exec rm -rf {} \;
    -name "*.log"    目标文件类型
    -exec    固定写法
    rm -rf    强制删除包括目录在内的文件 
        例: rm -rf abc 将 abc 子目录及子目录中所有档案删除,并且不用确认 :
    {} \;    固定写法

3、将上面shell文件添加到Linux定时任务脚本


[root@aigoV_66 ~]# crontab -e      //进入定时任务编辑页面(编辑保存方法同上)

0 23 * * * /root/syncsystemtime.sh
05 01 * * * sh /root/project/rm.sh
0 01 * * * /root/auto_del_sjjk_log.sh    //每日凌晨一点执行该删除日志的脚本文件
~                                                                                                                                       
~                                                                                                                                       
                                                                                                                                   
~                                                                                                                                       
~                                                                                                                                       
~                                                                                                                                       
"/tmp/crontab.zvmT2t" 3L, 106C

进过上面一番操作后,服务器会在每日凌晨一点自动执行清理日志的操作。

  • 0
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在Linux中,可以使用crontab命令来定时清理日志文件。具体步骤如下: 1. 打开终端,输入以下命令来编辑crontab文件: ``` crontab -e ``` 2. 在打开的编辑器中添加如下内容,表示每凌晨2点清理日志文件: ``` 0 2 * * * rm /path/to/log/files/*.log ``` 其中,`/path/to/log/files`是日志文件的路径,`*.log`表示删除该路径下所有以`.log`为后缀的文件。 3. 保存并退出编辑器。现在,crontab将在每凌晨2点定时执行这个清理操作,从而自动删除指定目录下的日志文件。 ### 回答2: 在Linux系统中,日志文件是必不可少的组成部分,它可以记录系统运行过程中发生的各种事件和错误,并对问题排查、优化性能等方面提供支持。但是,由于日志文件会占据大量磁盘空间,如果不及时清理可能会导致磁盘空间不足的问题,从而影响系统运行。因此,定时清理日志文件是很有必要的。 以下是在Linux系统上定时清理日志文件的一些方法: 1. 使用logrotate logrotate是一款Linux系统中用于专门管理日志文件的工具,它支持各种日志文件的定期滚动、压缩和删除等操作。logrotate的配置文件在/etc目录下,可以设置生效时间、日志保存数量、压缩、提醒等属性。例如,执行以下命令可以每周清理/var/log目录下的所有日志文件: ``` 0 0 * * 0 /usr/sbin/logrotate /etc/logrotate.conf ``` 2. 使用Cron Job Cron是一款在Linux系统中定时执行任务的工具,可以用来定时清理日志文件。可以使用Cron Job来清理Linux系统中的日志文件,比如将所有日志文件压缩归档,只保留30以上的文件,然后将压缩的日志文件上传到远程机器备份。例如,执行以下命令可以每月清理/var/log目录下的所有日志文件: ``` 0 0 1 * * /usr/bin/find /var/log -name "*.log" -mtime +30 -exec tar -cvzf /tmp/mylog.tar.gz {} \; && scp /tmp/mylog.tar.gz user@example.com:/backup/ ``` 3. 使用系统自带工具 Linux系统还自带一些其他工具可以清理日志文件,例如,使用find命令和xargs命令。 find命令可以查找特定的文件,xargs命令可以对查找的文件进行操作。例如,执行以下命令可以每清理/var/log目录下7前的所有日志文件: ``` 0 0 * * * find /var/log -mtime +7 -name "*.log" -type f -print0 | xargs -0 rm -f ``` 总之,定时清理日志文件Linux系统管理的必要操作,它可以节省磁盘空间并提高系统的稳定性和性能。根据实际情况和需要,可以选择不同的工具和方法来实现这个目的。 ### 回答3: Linux系统中,有很多日志文件会随着时间的推移不断地增加,从而占据磁盘空间,并使磁盘使用效率降低。为了避免这种情况的出现,我们可以使用定时清理日志文件的方法。 Linux中定时清理日志文件有很多种方式,这里我将介绍两种常用的方法。 1. 使用logrotate命令 logrotate命令Linux系统中一个用于管理日志文件的实用工具,它可以根据规则自动地旋转、清理和压缩日志文件,从而避免日志文件过多占用磁盘空间。使用logrotate的步骤如下: (1)编辑配置文件。 在/etc/logrotate.d目录下创建一个新的文件,命名为需要清理日志文件名。例如,如果要清理nginx服务器的访问日志,可以创建一个文件/etc/logrotate.d/nginx,将下列配置内容复制至该文件中: /var/log/nginx/access.log { daily rotate 7 compress delaycompress missingok notifempty create 0644 root root } 其中,daily表示每执行一次清理操作,rotate 7表示保留7个备份文件,compress表示压缩备份文件,missingok表示如果日志文件不存在,则跳过不做处理,notifempty表示如果日志文件为空,则跳过不做处理,create 0644 root root表示创建新日志文件的权限和属主。 (2)测试logrotate配置。 使用以下命令可以测试logrotate配置是否正确: logrotate -d /etc/logrotate.d/nginx 该命令会列出logrotate将要执行的操作,如果显示正确,则可以执行下一步。 (3)添加日志清理任务。 使用以下命令将任务添加到cron表中: 0 0 * * * /usr/sbin/logrotate /etc/logrotate.d/nginx >/dev/null 2>&1 该命令表示每午夜12点执行一次logrotate命令,/dev/null是输出到空设备,2>&1是将错误信息输出到标准输出(即/dev/null) 2. 使用systemd-tmpfiles 使用systemd-tmpfiles也可以清理日志文件,它是systemd工具的一部分,可以用于管理临时文件和目录。使用systemd-tmpfiles的步骤如下: (1)编辑配置文件。 在/etc/tmpfiles.d目录下创建一个新的文件,命名为需要清理日志文件名。例如,如果要清理/var/log/nginx/access.log文件,可以创建一个文件/etc/tmpfiles.d/nginx.conf,将下列配置内容复制至该文件中: #Type Path Mode Age Argument r /var/log/nginx/access.log 0644 7d - 其中,r表示删除目标文件,/var/log/nginx/access.log是目标文件的路径,0644是创建新日志文件的权限和属主,7d表示删除7以前的文件,-表示没有额外的参数。 (2)添加日志清理任务。 使用以下命令将任务添加到cron表中: 0 0 * * * /usr/bin/systemd-tmpfiles --clean >/dev/null 2>&1 该命令表示每午夜12点执行一次systemd-tmpfiles命令,--clean选项用于清理临时文件和目录,/dev/null是输出到空设备,2>&1是将错误信息输出到标准输出(即/dev/null)。 综上所述,以上两种方法都可以使Linux系统自动清理日志文件,避免磁盘空间不足的情况。如果需要清理其他类型的日志文件,也可以根据需要修改以上方法的配置文件
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值