900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > Linux服务器定时清理日志文件 Linux cron定时任务

Linux服务器定时清理日志文件 Linux cron定时任务

时间:2021-01-17 22:27:07

相关推荐

Linux服务器定时清理日志文件 Linux cron定时任务

文章目录

1、 准备工作2、 脚本实现2.1 执行命令准备2.2、Linux 下创建定时任务-crontab2.2.1、crontab 常用命令2.2.2 命令行操作 3、附甜点cron校验在线工具: https://tool.lu/crontab/cron Linux上的表达式说明SpringBoot下cron表达式使用

SpringBoot项目,日志不再写在数据库里,而是写在服务器的日志文件中,这样项目初期没有问题,但是时间久了就会导致服务器上的日志文件越来越多,内存占用也越来越大,这样肯定不行!人工维护?No!这里提供一个简单粗暴的解决方式,即利用 Linux 的 crontab 定时任务来实现,当练手了。 定时备份当前 console.log 日志文件清空当前 console.log 日志文件内容定时清理 console.log 备份日志文件定时清理 log-info.log 备份日志文件

1、 准备工作

先了解下此文 demo 项目的文件目录结构,大家后续根据需要适当调整脚本即可。 我这个项目是一个简单的 springboot 项目,没有结合 ES、kafka 等做日志平台处理。

sh 文件维护在:/home/deploy/logdeal-task.sh日志文件根:/home/logs/gemp-data,如图

重点:这里说明一下这些日志文件含义 console.log: 是服务器启动命令 /home/deploy/gemp-data.sh 中将日志都打印到了这里,类似 nohup.out、catalina.out等。log_info.log:程序中 info 级别的日志/info 目录:是对 log_info.log 的备份,这个机制在 SpringBoot 的 logbak.xml 中实现的。并且在备份后会自动清理当前 log_info.log/bak目录: 是这里我对 console.log 的备份目录,与 /info 区别在于,console.log 我需要手动清理一下。

2、 脚本实现

2.1 执行命令准备

创建文件:touch /home/deploy/logdeal-task.sh授权(日志任务如果没有权限也需要授权一下):chmod +x logdeal-task.sh编辑操作命令 定时备份当前 console.log 日志文件清空当前 console.log 日志文件内容定时清理 console.log 备份日志文件定时清理 log-info.log 备份日志文件——》这一步不做也可以,因为 logback.xml 中也能实现自动清理,如

<!--日志文件保留天数--><maxHistory>15</maxHistory>

#!/bin/sh# 备份 console.log ——> 清空当前 console.log 内容 ——> 清理 bak 下的 n 天前的 console.log 备份文件——> 清理info下的 n 天前的日志文件# 先备份console.log日志文件, 如果是其他的,参考改下名字即可mkdir /home/logs/gemp-data/bakcp -r /home/logs/gemp-data/console.log /home/logs/gemp-data/bak/$(date +%Y%m%d).log# 清空当前 console.log,释放空间cat /dev/null > /home/logs/gemp-data/console.log# 清理15天前的console.log日志文find /home/logs/gemp-data/bak/ -name "*.log" -mtime +15 -exec rm -rf {} \;# 清理15天前的log-info.log日志文find /home/logs/gemp-data/info/ -name "*.log" -mtime +15 -exec rm -rf {} \;

2.2、Linux 下创建定时任务-crontab

2.2.1、crontab 常用命令

-e #编辑定时任务

-l #查看定时任务

-r #删除定时任务

-u #指定其他用户

2.2.2 命令行操作

crontab -e输入i回车,输入下面命令,每天凌晨4点01分执行【也可以直接编辑:/var/spool/cron】

01 04 * * * /home/deploy/logdeal-task.sh >/dev/null 2>&1

每隔1分钟执行一次可以这样写

/1 * * * * /home/deploy/logdeal-task.sh >/dev/null 2>&1

输入 ESC 然后输入 :wq 保存重启crond服务

service crond restart

查看任务【也可以直接到 /var/spool/cron 下查看】:

crontab -l

查看日志 /var/log 文件中

tail -f /var/log/cron

3、附甜点

cron校验在线工具: https://tool.lu/crontab/

cron Linux上的表达式说明

SpringBoot下cron表达式使用

@Scheduled 注解也支持 cron 表达式,可以非常丰富的描述定时任务的时间。cron 表达式格式如下:

[秒] [分] [小时] [日] [月] [周] [年]

通配符含义:

“?” 表示不指定值,即不关心某个字段的取值时使用。需要注意的是,月份中的日期和星期可能会起冲突,因此在配置时这两个得有一个是 ?“*” 表示所有值,例如:在秒的字段上设置 *,表示每一秒都会触发“,” 用来分开多个值,例如在周字段上设置 “MON,WED,FRI” 表示周一,周三和周五触发“-” 表示区间,例如在秒上设置 “10-12”,表示 10,11,12秒都会触发“/” 用于递增触发,如在秒上面设置”5/15” 表示从5秒开始,每增15秒触发(5,20,35,50)“##” 序号(表示每月的第几个周几),例如在周字段上设置”6##3”表示在每月的第三个周六,(用 在母亲节和父亲节再合适不过了)周字段的设置,若使用英文字母是不区分大小写的 ,即 MON 与mon相同“L” 表示最后的意思。在日字段设置上,表示当月的最后一天(依据当前月份,如果是二月还会自动判断是否是润年), 在周字段上表示星期六,相当于”7”或”SAT”(注意周日算是第一天)。如果在”L”前加上数字,则表示该数据的最后一个。例如在周字段上设置”6L”这样的格式,则表示”本月最后一个星期五”“W” 表示离指定日期的最近工作日(周一至周五),例如在日字段上设置”15W”,表示离每月15号最近的那个工作日触发。如果15号正好是周六,则找最近的周五(14号)触发, 如果15号是周未,则找最近的下周一(16号)触发,如果15号正好在工作日(周一至周五),则就在该天触发。如果指定格式为 “1W”,它则表示每月1号往后最近的工作日触发。如果1号正是周六,则将在3号下周一触发。(注,”W”前只能设置具体的数字,不允许区间”-“)L 和 W 可以一组合使用。如果在日字段上设置”LW”,则表示在本月的最后一个工作日触发(一般指发工资 )

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。