Linux nohup 后台启动 jar包 定时按日期分割日志
在SpringBoot应用开发中,常用jar包方式进行部署,用nohup后台启动,这样生成的日志文件会越来越大,导致日志文件打开很慢,不方便后续问题的定位和解决。所以需要对日志进行分割,下面主要介绍按日期分割日志。话不多说,直接开始。
1、准备shell脚本log.sh
# !/bin/sh
log_dir="/www/wwwroot/java/haibao/log"
# 拷贝日志文件到昨天的log中
cp $log_dir/nohup.out $log_dir/nohup`date -d yesterday +%Y%m%d`.log
# 清空nohup.out日志
cat /dev/null > $log_dir/nohup.out
# 删除14天以前的日志
find $log_dir -mtime +14 -name 'nohup*.log' -exec rm -rf {} \;
2、手动执行一下log.sh
可能遇到的问题1:提示权限不够
解决办法:chmod 777 ./log.sh
可能遇到的问题2:文件格式问题
解决办法:sed -i 's/\r//g' log.sh
3、加入至定时任务中
#输入以下命令,按i执行插入
crontab -e
#设置执行任务,每天凌晨执行
0 0 * * * /www/wwwroot/java/haibao/log.sh
#按Esc键后再输入:wq,回车保存
:wq 回车
#查看是否创建成功
crontab -l
4、使其定时任务生效
执行以下命令:
service crond restart
Unit crond.service could not be found.
这是因为Ubuntu上的服务名称是cron不是crond
。所以你的命令应该是:
sudo service cron start
至此,大功告成,每天1个日志文件,当天的日志存于nohup.out中,自动删除14天以前的日志,只保留近15天的日志。
补充启动运行项目命令:
nohup java -jar xxxxx.jar >/www/wwwroot/java/haibao/log/nohup.out &
阅读剩余
版权声明:
作者:理想
链接:https://www.imyjs.cn/archives/1262
文章版权归作者所有,未经允许请勿转载。
THE END