SHELL脚本定期删除日志文件(日志定期清理) |
您所在的位置:网站首页 › 清理log文件 › SHELL脚本定期删除日志文件(日志定期清理) |
假设我们的应用每天会产生一个日志文件,但我们并没有对日志文件做任何归档处理,久而久之日积月累,就会将磁盘空间占满,从而影响系统的正常运行。 分析磁盘空间占用情况#当前磁盘空间占用情况 df -h#当前目录文件大小列表 ll -lh#文件列表按时间排序 ll -rt#文件大小列表,按时间排序 ll -lhrt#查询20天前的日志 find * -name 'server02.log007*' -mtime +20#删除20天前的日志 find * -name 'server02.log007*' -mtime +20 -exec rm -rf {} \;那么,如何定期清理过期的日志文件呢?方法一:应用实现 方法二:shell脚本定期清理应用实现的方式这里就不做过多的介绍,本文着重讲解下如何编写shell脚本定期清理日志文件。 步骤一:编写自动清理日志文件shell脚本# vim logAutoClean.sh #!/bin/bash log_path="/home/server/core/logs/app" #目录存在,删除修改时间为7天前的文件 if [ -d "${log_path}" ]; then echo start delete log 7 days ago... find "${log_path}"/* -name '*.log.gz' -mtime +240 -exec rm -rf {} \; echo end delete log ... fi# :wq! 保存并退出 步骤二:脚本文件授权(可执行权限)# chmod +x logAutoClean.sh测试一下: # sh logAutoClean.sh步骤三:创建crontab定时任务# crontab –e进入编辑页面(第一次进入会让你选择编辑器,这里我们选择3[vim.basic]就ok)。 设置每天凌晨1点执行(假定清除脚本在目录/home/server/core/logs/app下),编辑crontab,增加如下行:00 01 * * * /home/server/core/logs/app/logAutoClean.sh可先设置五分钟执行一次,测试下脚本*/5 * * * * /home/server/core/logs/app/logAutoClean.sh如果定时任务不生效,重启下crond服务# service crond restart //重启服务附录:crontab用法说明crontab命令用于安装、删除或者列出用于驱动cron后台进程的表格。用户把需要执行的命令序列放到crontab文件中以获得执行。每个用户都可以有自己的crontab文件。/var/spool/cron下的crontab文件不可以直接创建或者直接修改。该crontab文件是通过crontab命令创建的在crontab文件中如何输入需要执行的命令和时间。该文件中每行都包括六个域,其中前五个域是指定命令被执行的时间,最后一个域是要被执行的命令。每个域之间使用空格或者制表符分隔。格式如下: 格 式: minute hour day-of-month month-of-year day-of-week commands 合法值: 00-59 00-23 01-31 01-12 0-6 (0 is sunday)除了数字还有几个个特殊的符号就是"*"、"/"和"-"、",",*代表所有的取值范围内的数字,"/"代表每的意思,"/5"表示每5个单位,"-"代表从某个数字到某个数字,","分开几个离散的数字。 crontab 命令 -l 在标准输出上显示当前的crontab。 -r 删除当前的crontab文件。 -e 使用VISUAL或者EDITOR环境变量所指的编辑器编辑当前的crontab文件。当结束编辑离开时,编辑后的文件将自动安装。 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |