• 【监听服务器】自动重启脚本


    大家好,我是梦辛工作室的灵,又有 好长一段时间没有更新了,主要我也没撒好更新了,不过最近终于又知道更新撒了,昨天晚上半夜服务器奔溃,给我整的,恼火的,大半夜起来重启服务器,气的我今天撒也不说,写了一个监听 服务器 运行的脚本,并自动重启的,感觉还不错,放到下面了

    #!/bin/bash
    # 函数需要提前声明
    
    function doReStartServer() {
    	restart_now=`date -d "now" +%Y-%m-%d`
    	echo "$(date "+%Y-%m-%d %H:%M:%S") 开始重启服务器" >> logs/${restart_now}_server.log
    	echo "$(date "+%Y-%m-%d %H:%M:%S") 开始重启服务器" >> logs/${restart_now}_run.log
    	PID=`ps -ef | grep $binfile | grep -v grep | awk '{print $2}'`
    	if [ ${#PID} -gt 0 ] 
    	then 
    	#进程还在。结束进程
    		echo "$(date "+%Y-%m-%d %H:%M:%S") 关闭服务器" >> logs/${restart_now}_server.log
    		echo "$(date "+%Y-%m-%d %H:%M:%S") 关闭服务器" >> logs/${restart_now}_run.log
    		sh ${binfile}bin/shutdown.sh
    		sleep 30
    	fi 
    	echo "$(date "+%Y-%m-%d %H:%M:%S") 启动服务器" >> logs/${restart_now}_server.log
    	echo "$(date "+%Y-%m-%d %H:%M:%S") 启动服务器" >> logs/${restart_now}_run.log
    	sh ${binfile}bin/startup.sh
    	sleep 30
    	echo "$(date "+%Y-%m-%d %H:%M:%S") 检查服务器" >> logs/${restart_now}_server.log
    	echo "$(date "+%Y-%m-%d %H:%M:%S") 检查服务器" >> logs/${restart_now}_run.log
    	REPID=`ps -ef | grep $binfile | grep -v grep | awk '{print $2}'`
    	if [ ${#REPID} -gt 0 ] 
    	then
    		echo "$(date "+%Y-%m-%d %H:%M:%S") 服务器重启成功" >> logs/${restart_now}_server.log
    		echo "$(date "+%Y-%m-%d %H:%M:%S") 服务器重启成功" >> logs/${restart_now}_run.log
    	else
    		doReStartServer 
    	fi
    }
    
    #检查状态
    function doCheckServer () {  
     if [ $1 -eq "200" -o $1 -eq "404"  -o $1 -eq "500" ] 
     then 
    	echo "$(date "+%Y-%m-%d %H:%M:%S") 服务器正常" >> logs/${2}_run.log
     else
    	echo "$(date "+%Y-%m-%d %H:%M:%S") 服务器异常" >> logs/${2}_run.log 
    	doReStartServer  
     fi  
    } 
     
    
    #单次访问最长时间
    timeout=10
    
    #重复访问几次
    retry=3
    
    #多久检查一次(秒)
    sleeptime=20
    
    #域名
    server="localhost"
    
    #启动文件所在目录
    binfile="/home/tomcat/"
    
    #创建日志文件夹
    mkdir -p logs
    
    startnow=`date -d "now" +%Y-%m-%d`
    
    echo "$(date "+%Y-%m-%d %H:%M:%S") 程序开始运行" >> logs/${startnow}_start.log
    
    while :
    do
    	now=`date -d "now" +%Y-%m-%d`
    	  
    	#statements
    	echo "$(date "+%Y-%m-%d %H:%M:%S") 访问$server" >> logs/${now}_run.log
    
    	code=`curl -o /dev/null -s -w %{http_code} --max-time $timeout   --retry $retry --url $server`
     	
    	echo "$(date "+%Y-%m-%d %H:%M:%S") 访问结果$code" >> logs/${now}_run.log
    	
    	doCheckServer $code $now
     	
    	sleep $sleeptime
    	
    done
     
    echo "$(date "+%Y-%m-%d %H:%M:%S") 程序结束运行" >> logs/${startnow}_start.log
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84

    把他放在服务器上,然后 ,更改下上面的配置信息,就可以了,目前是 视为 返回 200 500 404 都视为正常情况,其他返回码都视为 异常,

    放到服务器上后,输入

    cd 文件所在文件夹
    chmod +x autocheck.sh
    ./autocheck.sh &
    
    • 1
    • 2
    • 3

    然后就可以了,可以去跟踪日志文件,示例如下

    cd logs
    tail -f 今日_run.log
    
    • 1
    • 2
  • 相关阅读:
    大数据之DStream 转换 完整使用 (第十四章)
    kettle数据迁移从oracle到mysql
    Java----模拟学生成绩管理系统
    C++ - 搜索二叉树
    C语言·对文件的输入输出(万字详解)
    C++ Qt开发:使用关联容器类
    六要素一体微型气象站介绍
    软件测试13年从业经验的前辈,总结的5条测试就业建议....
    Spring Bean作用域简介说明
    vue项目打包优化的方法
  • 原文地址:https://blog.csdn.net/weixin_41392105/article/details/125461900