本文主要是介绍python脚本监控windows系统上的tomcat实现故障自愈,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1、通过访问url判断http访问状态不为200,则重启tomcat。
出于生产环境的安全性需要,这里不敢使用python的request模块去请求url,怕会出现问题。
2、调用的vbs文件,可查看 https://blog.csdn.net/qq_41842739/article/details/122965230?spm=1001.2014.3001.5501
#-*- coding:utf-8 -*-
#auth chenzelin
import string
import psutil
import sys
import time
import ossaveFilePath = "E:\\agent\\winAgent\\temp" #本地文件保存的路径,需要修改
returndate = time.strftime('%Y-%m-%d %H:%M:%S....',time.localtime())
proc_list=[]
def get_pid(pname):for proc in psutil.process_iter():
#print(“pid-%d,name:%s” % (proc.pid,proc.name()))if proc.name() == pname:return proc.piddef cmd(cmd_name):os.system(cmd_name) def stop(a):time.sleep(a) msg = os.popen('cscript //Nologo E:\\check-code\\netstatus.vbs').read()
#
start_cmd='net start tomcat8'
stop_cmd='net stop tomcat8'
stop_kill_cmd='taskkill /f /im tomcat8.exe'
tomcat_status = get_pid("tomcat8.exe")
procmmm=''
if msg.strip() != "200":procmmm += '【自愈结果】脚本执行时间:'+returndate+'1、当前进程号:'+ str(tomcat_status)+'....'if get_pid("tomcat8.exe") == None:procmmm += '2、服务挂停....'start1=cmd(start_cmd)if start1 != 0:procmmm += '3、服务已恢复....当前进程号:'+str(get_pid("tomcat8.exe")) else: procmmm += '2、服务挂死,正尝试自愈....'cmd(stop_cmd) #先停止服务stop(30)procmmm += '3、开始清理残留....'rst = cmd(stop_kill_cmd) stop(30)if rst != 0 :procmmm +='4、结束清理残留....'else:procmmm +='4、不存在残留,服务已停止....' procmmm +='5、执行恢复操作....' start21 = cmd(start_cmd)if start21 != 0 :tomcatB_status = get_pid("tomcat8.exe")procmmm += '6、自愈完成,当前进程号:'+str(tomcatB_status)else:procmmm +='6、自愈异常,需要人工干预'else:procmmm = '【执行结果】脚本执行时间:'+returndate+'200'#将脚本运行结果保存在指定txt文件中
localPath = os.path.join(saveFilePath,'故障自愈信息.txt')
with open(localPath,'a') as f: f.write(procmmm+'\n')f.close
3、脚本执行结果
执行结果参考:
4、另外
net start tomcat8,指的是计算机管理–服务–服务名
taskkill /f /im tomcat8.exe 指的是强制停止任务管理器的进程
这篇关于python脚本监控windows系统上的tomcat实现故障自愈的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!