第一种方案,每天凌晨三点重启jar包

1、创建脚本文件server.sh

touch server.sh


2、将.sh文件变为可执行文件

chmod +x server.sh


3、编辑脚本文件(shell脚本必须包含 #!/bin/bash 不然shell脚本无法执行)

!/bin/bash
ID=ps -ef | grep server.jar | grep -v 'grep' | awk '{print $2}' #注意查询出bash本身的进程号
echo $ID
echo "--------------"
for id in $ID
do
kill -9 $id
echo "killed $id"
done
sleep 2
echo "restart begin"
source /etc/profile
java -jar server.jar > /root/yxkjJar/server.log &
processID=ps -ef | grep server.jar | grep -v 'grep' | awk '{print $2}'
echo "restart success $processID"

4、完成之后使用./server.sh测试一下脚本文件是否可以执行

可能会报错
-bash: ./server.sh: /bin/bash^M: bad interpreter: No such file or directory

1、查看文件格式,dos格式的文件行尾为^M$,unix格式的文件行尾为$
cat -A server.sh
2、使用替换命令替换为unix格式
sed -i "s/\r//" server.sh
3、再看文件是dos格式还是unix格式
cat -A server.sh

5、配置定时任务

1.编辑定时任务
crontab -e
2.写定时任务时间
(我的是凌晨三点重启 依次是 分钟 0——59、小时0-23、天1-31、月1-12、星期0-7 0或者7表示星期天)
0 3 * * * /root/yxkjJar/server.sh >> /root/yxkjJar/cron.log 2>&1
3.查看意见配置的定时任务列表
crontab -l
4.重新加载crond服务
/sbin/service crond reload
5.查看定时任务执行日志
tail -f /var/log/cron


第二种方案,监听jar包是否宕机,若宕机自动启动脚本

1、编写脚本(每10s监听一次)sys.sh

#!/bin/bash  
  
LOGFILE="/root/yxkjJar/sys.log"  
  
while :   
do   
  run=$(ps -ef |grep "server.jar" |grep -v "grep")   
  if [ "$run" ] ; then   
    TIMESTAMP=$(date +"%Y-%m-%d %H:%M:%S")  
    echo "[$TIMESTAMP] The service is healthy!" >> $LOGFILE  
  else   
    TIMESTAMP=$(date +"%Y-%m-%d %H:%M:%S")  
    echo "[$TIMESTAMP] The service is down!" >> $LOGFILE  
    echo "[$TIMESTAMP] Starting service ..." >> $LOGFILE  
    nohup java -jar server.jar > /root/yxkjJar/server.log 2>&1 &  
    echo "[$TIMESTAMP] The service was started!" >> $LOGFILE  
  fi   
  sleep 10  
done

2、修改脚本文件权限

chmod 777 sys.sh

3、处理脚本无法运行异常:报错syntax error near unexpected token `$'\r''解决方法

sed -i 's/\r//g' sys.sh

4、启动脚本

nohup ./sys.sh > sys.log &

休闲、娱乐、爱生活