当前位置: 代码网 > it编程>前端脚本>Python > python监控windows服务器的进程和服务

python监控windows服务器的进程和服务

2025年04月21日 Python 我要评论
需求:软件公司提供的软件服务在服务器上会莫名其妙的挂掉,他们采用的方法也只有重启服务器,重启时间太久了,所以想弄一个监测进程和服务的程序,监测到挂了就重启进程或者服务import psutil im

需求:软件公司提供的软件服务在服务器上会莫名其妙的挂掉,他们采用的方法也只有重启服务器,重启时间太久了,所以想弄一个监测进程和服务的程序,监测到挂了就重启进程或者服务

import psutil  
import time
import subprocess
import logging
import logging.handlers
import wmi
import ctypes
import os

# 获取服务状态
def get_service_status(service_names):
    wmiobj = wmi.wmi()
    for service_name in service_names:
        services = wmiobj.win32_service(name = service_name)
        if services:
            # 服务状态是停止就开启服务
            if services[0].state == "stopped":
                start_service(service_name)
            # return services[0].state
        else:
            logging.error(f"失败:服务{service_name}不存在")

#判断是否有管理员权限
def is_admin():
    try:
        return ctypes.windll.shell32.isuseranadmin()
    except:
        return false

# 启动服务
def start_service(service_name):
    if is_admin():
        try:
            cmd = 'net start {}'.format(service_name)
            os.popen(cmd)
            logging.warning(f"成功:启动了服务{service_name}")
        except exception as e:
                logging.error(f"失败:启动服务{service_name}失败, 错误信息: {e}")
    else:
        logging.warning(f"不是admin权限")

# 日志配置
def loggingstars():
    logger = logging.getlogger()
    logger.setlevel(logging.debug)

    handler = logging.streamhandler()
    logger.addhandler(handler)

    file_handler = logging.handlers.rotatingfilehandler(filename='process_name.log', maxbytes=1024*1024*90, backupcount=10)
    file_handler.setlevel(logging.warning)

    formatter = logging.formatter('%(asctime)s - %(levelname)s - %(message)s')
    file_handler.setformatter(formatter)

    logger.addhandler(file_handler)


# 获取掉线的进程完整执行路径
def find_process_by_name(process_names): 
    all__process = set()
    """获取所有进程的完成路径"""  
    for proc in psutil.process_iter(['pid', 'name','exe']):
        all__process.add(proc.info['exe']) 
    """ 找出掉线的监控进程的完整路径 """
    new_list = [item for item in process_names if item not in all__process]
    return new_list


def start_process(process_names, service_anmes):
    while true:
        # 检查服务是否启动
        get_service_status(service_anmes)
        time.sleep(60)

        stop_process = find_process_by_name(process_names)
        
        if not stop_process:
            continue
        """ 启动掉线的进程 """
        for app in stop_process:
            try:
                subprocess.popen(f"{app}")
                logging.warning(f"成功:启动了进程{app}")
            except exception as e:
                logging.error(f"失败:启动进程{app}失败, 错误信息: {e}")
        # 如果需要启动进程的话,暂停20分钟
        time.sleep(20*60)
  
if __name__ == "__main__":

    loggingstars()

    logging.warning("============== 进程监控程序启动 ============")

    # 需要监测的进程,为什么使用可执行文件,是因为发现有进程名会相同
    process_names = [
        "c:\\userapp\\app\\baidu-translate-client\\百度翻译.exe",
        "c:\\userapp\\app\\dingding\\main\\current\\dingtalk.exe"
    ]

   # 需要监测的服务名
    service_anmes = ["mysql80", "jetbrainsetwhost"]
    start_process(process_names, service_anmes)

其实服务也是启动执行文件然后有一个进程,如果找到所有服务的进程直接写进程监控就可以了,这里只是展示一下怎么监控服务和进程

有些服务或者进程的启动可能有顺序

  • 打开 运行 输入 “msinfo32”
  • 选择 “软件环境” 再点击 "正在运行任务"就可疑查看启动时间

打包就用 pyinstaller -f xx.py,然后放到服务器上

到此这篇关于python监控windows服务器的进程和服务的文章就介绍到这了,更多相关python监控服务器进程和服务内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com