热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

用WMI监控IIS

参考网站:http:blog.chinaunix.netuid-7910284-id-5774420.html参考官方文档:https:docs.microsoft.comen-u

参考网站:http://blog.chinaunix.net/uid-7910284-id-5774420.html

参考官方文档:https://docs.microsoft.com/en-us/previous-versions//aa394298(v=vs.85)


获取服务信息

from win32com.client import GetObject
import wmi,sys,argparse,subprocess

parser = argparse.ArgumentParser( usage = 'check_win_service.py -t xx -n xxxx -cw xx.xx -cc xx.xx -mw xx.xx -mc xx.xx', description='to check windows iis thrift or process usages' )
parser.add_argument( '-t', dest='type', metavar='string', type=str, required=True, help='resource type:iis|srv|app' )
parser.add_argument( '-n', dest='name', metavar='string', type=str, required=True, help='service or app name' )
parser.add_argument( '-cw', dest='cpuwarn', metavar='float', type=float, nargs='?', cOnst=80.00, help='warning value for cpu,default 80%' )
parser.add_argument( '-cc', dest='cpucrit', metavar='float', type=float, nargs='?', cOnst=90.00, help='critial value for cpu,default 90%' )
parser.add_argument( '-mw', dest='memwarn', metavar='float', type=float, nargs='?', cOnst=15.00, help='warning value for mem,default 15%' )
parser.add_argument( '-mc', dest='memcrit', metavar='float', type=float, nargs='?', cOnst=20.00, help='critial value for mem,default 20%' )
parser.add_argument( '-tw', dest='tcpwarn', metavar='int', type=int, nargs='?', cOnst=800, help='warning value for tcp,default 800' )
parser.add_argument( '-tc', dest='tcpcrit', metavar='int', type=int, nargs='?', cOnst=1000, help='critial value for tcp,default 1000' )
args = parser.parse_args()


def iis_usage(iisname):
    wmi = GetObject('winmgmts:/root/cimv2')
    iisbase = wmi.ExecQuery('select * from Win32_PerfFormattedData_W3SVCW3WPCounterProvider_W3SVCW3WP where Name like "%{}"'.format(iisname))

    for item in iisbase:
        iispid = item.Name.split('_')[0]

    iisstatus = []

    try:
        iisinfo = wmi.ExecQuery('select * from Win32_PerfFormattedData_PerfProc_Process where IDProcess = "{}"'.format(iispid))
    except UnboundLocalError as nopid:
        print("CRITIAL - {} was down".format(iisname))
        sys.exit(2)

    for item in iisinfo:
        iisstatus.append(item.PercentProcessorTime)
        iisstatus.append(round(float(item.WorkingSetPrivate)/1024/1024,2))
    iiscon = wmi.ExecQuery('select * from Win32_PerfFormattedData_W3SVC_WebService where Name = "{}"'.format(iisname))
    for item in iiscon:
        iisstatus.append(item.CurrentConnections)

    return(iisname,iispid,iisstatus)	

	
def srv_usage(srvname):
    wmi = GetObject('winmgmts:/root/cimv2')
    srvbase = wmi.ExecQuery('select * from Win32_Service where Name = "{}"'.format(srvname))

    for item in srvbase:
        srvpid = item.ProcessId

    srvstatus = []

    try:
        srvinfo = wmi.ExecQuery('select * from Win32_PerfFormattedData_PerfProc_Process where IDProcess = "{}"'.format(srvpid))
    except UnboundLocalError as nopid:
        print("CRITIAL - {} was down".format(srvname))
        sys.exit(2)

    for item in srvinfo:
        srvstatus.append(item.PercentProcessorTime)
        srvstatus.append(round(float(item.WorkingSetPrivate)/1024/1024,2))
    srvstatus.append(subprocess.getstatusoutput('netstat -ano | findstr {} | wc -l'.format(srvpid))[1])
    
    return(srvname,srvpid,srvstatus)

def app_usage(appname):
    wmi = GetObject('winmgmts:/root/cimv2')
    appbase = wmi.ExecQuery('select * from Win32_Process where CommandLine like "%{}%" and Caption != "python.exe"'.format(appname))
    for item in appbase:
        apppid = item.ProcessId

    appstatus = []

    try:
        appinfo = wmi.ExecQuery('select * from Win32_PerfFormattedData_PerfProc_Process where IDProcess = "{}"'.format(apppid))
    except UnboundLocalError as nopid:
        print("CRITIAL - {} was down".format(appname))
        sys.exit(2)

    for item in appinfo:
        appstatus.append(item.PercentProcessorTime)
        appstatus.append(round(float(item.WorkingSetPrivate)/1024/1024,2))
    appstatus.append(subprocess.getstatusoutput('netstat -ano | findstr {} | wc -l'.format(apppid))[1])
    
    return(appname,apppid,appstatus)
	
def judgement(judgetype,judgename,judgecpuw,judgecpuc,judgememw,judgememc,judgeconw,judgeconc):
    wmi = GetObject('winmgmts:/root/cimv2')
    totalmem = wmi.ExecQuery('select * from Win32_PhysicalMemory')
    memtotal = 0
    for item in totalmem:
        memtotal += round((float(item.Capacity)/1024)/1024,2)
    
    if judgetype == 'iis':
        stu = iis_usage(args.name)
    elif judgetype == 'srv':
        stu = srv_usage(args.name)
    elif judgetype == 'app':
        stu = app_usage(args.name)
    else:
        print("there have not this type")
        sys.exit(3)

    statstr = "OK"
    status = 0
    cp = float(stu[2][0])
    mp = round((float(stu[2][1])/memtotal)*100, 2)
    tp = int(stu[2][2])
    if cp 

  获取资源信息

from win32com.client import GetObject
import wmi,sys,argparse

parser = argparse.ArgumentParser( usage = 'check_win_network.py -w xx.xx -c xx.xx', description='to check linuxs mem or net usages' )
parser.add_argument( '-t', dest='type', metavar='string', type=str, required=True, help='resource type:mem|net' )
parser.add_argument( '-d', dest='devs', metavar='string', type=str, nargs='?', cOnst="eth0", help='network card name,do not define it if type is not "net"' )
parser.add_argument( '-w', dest='warn', metavar='float', type=float, nargs='?', cOnst=80.0, help='warning value,default 80' )
parser.add_argument( '-c', dest='crit', metavar='float', type=float, nargs='?', cOnst=90.0, help='critial value,default 90' )
args = parser.parse_args()


def net_usage(dev="eth0", warning=80.00, critical=90.00):
    wmi = GetObject('winmgmts:/root/cimv2')
    networks = wmi.ExecQuery('select * from Win32_PerfFormattedData_Tcpip_NetworkInterface')
    netinfo=[]
    for item in networks:
        if item.Name == dev:
            netinfo.append(item.Name)
            netinfo.append(round(float(item.BytesReceivedPersec)*8/1024/1024,2))
            netinfo.append(round(float(item.BytesSentPersec)*8/1024/1024,2))
            netinfo.append(round(float(item.BytesTotalPersec)*8/1024/1024,2))
            netinfo.append(round(float(item.CurrentBandwidth)/1000/1000,0))
            netinfo.append(item.PacketsReceivedPersec)
            netinfo.append(item.PacketsSentPersec)
            netinfo.append(item.PacketsPersec)

    exitflag = 0
    status="OK"

    warning_line = netinfo[4] * (warning/100)
    critical_line = netinfo[4] * (critical/100)
    usepec = round((netinfo[3] / netinfo[4]) * 100,2)
    tp = netinfo[3]
    if tp = critical_line:
        exitflag = 2
        status="CRITICAL"
    else:
        print("UNKNOW")
        sys.exit(3)

    print("{0} - {1} NetWork Usage: Network wide {2}Mbps, Use_Persent {3}%, Total_RX-TX {4}Mbps, RX {5}Mbps ,RX-package {6}, TX {7}Mbps, TX-package {8} | Use_Persent={3}%;;; Total_RX-TX={4}Mbps;{9};{10}; RX={5}Mbps;;; RX-package={6};;; TX={7}Mbps;;; TX-package={8};;;"
          .format(status,netinfo[0],netinfo[4],usepec,netinfo[3],netinfo[1],netinfo[5],netinfo[2],netinfo[6],warning_line,critical_line))
    sys.exit(exitflag)


def mem_usage(warning=80.00, critical=90.00):
    wmi = GetObject('winmgmts:/root/cimv2')
    totalmem = wmi.ExecQuery('select * from Win32_PhysicalMemory')
    freemem = wmi.ExecQuery('select * from Win32_PerfFormattedData_PerfOS_Memory')
    
    memtotal = 0.0
    memused = 0.0
    memfree = 0.0
    memcache = 0.0
    
    for item in totalmem:
        memtotal += round((float(item.Capacity)/1024)/1024,2)
    for item in freemem:
        memfree = float(item.AvailableMBytes)
        memcache = round(float(item.CacheBytes)/1024/1024,2)
        memused = memtotal - memfree

    exitflag = 0
    status="OK"
    warning_mem = round((warning/100) * memtotal,2)
    critical_mem = round((critical/100) * memtotal,2)
    
    if memused = critical_mem:
        exitflag = 2
        status="CRITICAL"
    else:
        print("UNKNOW")
        sys.exit(3)

    print("{0} - Mem Usage: Use_Persent {1}%, total {2}MB, free {3}MB, used {4}MB, cache-buffer {5}MB | Use_Persent={1}%;;; total={2}MB;;; free={3}MB;;; used={4}MB;{6};{7}; cache-buffer={5}MB;;;"
          .format(status,round((memused/memtotal)*100,2),memtotal,memfree,memused,memcache,warning_mem,critical_mem))
    sys.exit(exitflag)


    

if args.type == "mem":
    mem_usage(args.warn, args.crit)
elif args.type == "net":
    net_usage(args.devs,args.warn,args.crit)
else:
    print(args.type)
    print("no this types -h for help")

  

 


推荐阅读
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
author-avatar
手机用户2602938575
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有