文章目录
- 1、 准备工作
- 2、 脚本实现
- 2.1 执行命令准备
- 2.2、Linux 下创建定时任务-crontab
- 2.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/bak
cp -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”,则表示在本月的最后一个工作日触发(一般指发工资 )