java高级开发

Centos自动拉起脚本

2021-03-03  本文已影响0人  老鼠AI大米_Java全栈

项目上线之后,服务器有时候会莫名其妙的挂掉,利用shell写一个看门狗程序,监测服务器异常关闭后,重启服务器。

新建脚本文件,赋予权限

touch start.sh  
chmod 755 start.sh

编写脚本文件

#!/bin/sh

# 自动监控jar并且在异常时执行重启操作

# 定义java环境变量
export JAVA_HOME=/usr/local/myApp/jdk1.8

# 获取端口号为8711的jar进程ID
# grep -v grep 排除grep命令自带的进程id
# awk '{print $2}' 只保留结果中第二列的值
pid=$(ps -ef |grep 8711|grep -v grep|awk '{print $2}')

# 启动脚本
start=/usr/local/myApp/xxx/bin/start.sh

# 服务链接地址
url=http://192.168.6.179:8711/api/swagger-ui.html

# 监控时的日志输出
log=/tmp/my.log

#linux垃圾回收站
hole=/dev/null

function doIt()
{
  if [ $pid ]
    then
       echo "jar进程ID存在"
       code=$(curl -s -o $hole -m 10 --connect-timeout 10 $url -w %{http_code}"\n") #测试链接是否可以正常访问
       if [ $code -eq 200 ]
         then
           echo "测试链接正常"
       else
          echo "测试链接失败,重启jar"
          kill -9 $pid  # 杀掉进程
          sleep 5
          $start
     fi
  else
    echo "jar进程id不存在,重启中...."
    $start
  fi
  echo "------------------------------"
}
 
doIt>>$log #执行函数,并打印日志

设置定时执行start.sh文件

crontab -e

命令行输入crontab -e会自动打开一个空文件, 输入定时处理的任务:

#需要定时重启docker容器
#查看容器id: docker ps|grep netty
#yw-netty
0 2 * * * docker restart 234234234
#saas-yw-netty
0 2 * * * docker restart 4645645656

保存后,在/var/spool/cron/下面查看创建的定时任务。

添加内容:

*/30 * * * * /tmp/mySh/start.sh #每30分钟执行一次

启动定时任务

service crond start   #启动定时任务
 
service crond status  #查看状态
 
service crond restart #重启定时任务
 
service crond stop    #停止定时任务

查看定时任务执行情况

crontab -l

上一篇下一篇

猜你喜欢

热点阅读