本文介绍如何使用Shell脚本来开启和停止jar程序的后台运行,以及如何实现out大文件的切分。另外,补充一些后台运行的小知识。
启动脚本:start_upload.sh
#!/bin/sh
nohup java -jar UploadSchedule.jar >> /usr/local/tomcat9/webapps/upload-to-oss/nohup_upload.out 2>&1 &
echo $! > /var/run/UploadSchedule.pid
启动脚本说明:
1、开启后台执行,并将程序产生的日志文件写入out文件;
2、将当前进程id写入/var/run/UploadSchedule.pid,以供在停止脚本中使用此pid来停止当前进程。
停止脚本:stop_upload.sh
#!/bin/sh
PID=$(cat /var/run/UploadSchedule.pid)
kill -9 $PID
停止脚本说明:
1、首先获取进程id;
2、然后杀掉该进程。
文件切分:split_nohup.sh
程序不中断,一直在后台运行,那么产生的log也会持续输出到out问价,导致out文件越来越大。当需要根据out文件进行一些日志查找的时候,非常不方便。所以定期对out文件进行切分,按日期将当日out文件切分成若干小文件,从而方便处理及错误查找定位。
#!/bin/bash
log_path=/usr/local/tomcat9/webapps/upload-to-oss
if [ -f "$log_path/nohup_upload.out" ];then
current_date=`date -d "-1 day" "+%Y%m%d"`
cp $log_path/nohup_upload.out $log_path/nohup_upload_${current_date}.out
cat /dev/null > $log_path/nohup_upload.out
split -b 5242880 -d -a 4 $log_path/nohup_upload_${current_date}.out $log_path/nohup_upload_${current_date}_
rm -rf $log_path/nohup_upload_${current_date}.out
fi
切分脚本说明:
1、如果out文件存在,将nohup_upload.out文件复制一份,命名为nohup_upload_当前日期(比如nohup_upload_20200328.out);
2、将nohup_upload.out文件清空;
3、对nohup_upload_20200328.out文件进行切分,切分后的文件命名格式为nohup_upload_20200328_0001,nohup_upload_20200328_0002;
- -b 指定每个小文件的大小(单位byte)
- -d 以数字作为后缀
- -a 指定后缀的长度
4、将原文件(nohup_upload_20200328.out)删除。
执行开启/停止命令
# 启动
./start_upload.sh
# 停止
./stop_upload.sh
一些后台运行的小知识
&和nohup区别:
&的意思是在后台运行。意思是说, 当你在执行 ./start_upload.sh & 的时候, 即使你用Ctrl + C, 那么start_upload.sh照样运行(因为对SIGINT信号免疫)。 但是要注意, 如果你直接关掉Shell后, 那么, start_upload.sh进程同样消失。 因为对SIGHUP信号不免疫。
nohup的意思是忽略SIGHUP信号, 所以当运行nohup ./start_upload.sh的时候, 关闭Shell,start_upload.sh进程还是存在的(对SIGHUP信号免疫)。 但是如果你直接在Shell中用Ctrl + C, 那么,start_upload.sh进程也是会消失的(因为对SIGINT信号不免疫)
所以,要让进程真正不受Shell中Ctrl + C和Shell关闭的影响, 就用nohup和&同时用。
到此这篇关于使用Shell脚本如何启动/停止Java的jar程序的文章就介绍到这了,更多相关Shell 启动停止jar程序内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论