`

python通过ssh-powershell监控windows信息

阅读更多

 

Author:pako

Email&gtalk:zealzpc@gmail.com

 

对于服务器的监控来说,监控linux不管是自己动手写脚本还是用一些开源的工具比如nagios,zenoss什么的。但毕竟还是有些公司有windows做服务器的,相对linux来说,windows没有方便的shell,cmd下提供的命令对于监控来说远远没有linux方便。但是现在windows上如果安装了powershell(win7,2008自带),就比以前方便多了,linux上的命令基本都能在powershell里执行,比如查看进程还是ps.

 

自己封装了一个python通过ssh(通过pexpect模块)调用powershell的脚本,里面包快ps,netstat,ping检测,查看硬盘,cpu信息和负载,内存信息。通过创建ssh_win32类对象,然后调用它的方法,返回的都是解析好的python对象。

 

ssh_powershell.py

 

 

#! /usr/bin/env python
# -*- coding: utf-8 -*-
#Author:pako
#Email:zealzpc@gmail.com
import re
from pexpect import *
class ssh_win32:
    def __init__(self, user, host, password=None,systemroot='c',papath='',timeout=5,verbose=0):

        self.user = user#监控机器的username
        self.host = host#监控机器的ip
        self.verbose = verbose
        self.password = password#密码
        self.timeout=timeout#执行命令的timeout
        self.systemroot=systemroot#windows 所安装的盘符
        if not papath:#powershell.exe的路径
            self.powershell_path=self.systemroot+':/WINDOWS/system32/WindowsPowerShell/v1.0/powershell.exe '
        self.key = [
            'authenticity',
            'assword:',
            '@@@@@@@@@@@@',
            'Command not found.',
            EOF,
            ]
        
        self.f = open('ssh.out','w')

    def ssh(self,command):
        cmd='ssh -l %s %s %s'%(self.user,self.host,command)
        print "cmd:",cmd
        con=spawn(cmd,timeout=self.timeout)
        seen=con.expect(self.key)
        if seen == 0:
            con.sendline('yes')
            seen = con.expect(self.key)
        if seen == 1:
    #        if not self.password:
    #            self.password = getpass.getpass('Remote password: ')
            con.sendline(self.password)
            try:
                res=con.read()
            except Exception ,e:
                res=con.before
#            print "res:",res
        return res
    def ssh_disk(self):
        cmd=self.powershell_path+"Get-WmiObject win32_logicaldisk"
        res=self.ssh(cmd)
        disk={}
        if res:
            res=res.split('No such file or directory')[-1].replace('\r','').split('\n')
            res=[c for c in res if c]
#            print 'res:',res
        predisk='C'
        for d in res:
#            print d
            key,value=d.split(':',1)
#            print d
#            print 'key:',key,'value:',value
            key=key.strip()
            value=value.strip()
            if key=='DeviceID' and value not in disk.keys():
                predisk=value
                disk[predisk]={}
                disk[predisk][key]=value
            else:
                if key in ['FreeSpace','Size']:
                    if value:
                        value=int(value)/1024/1024/1024
                disk[predisk][key]=value
        for d in disk.keys():
            if disk[d]['DriveType']!='3':
                disk.pop(d)
#        print 'disk:',disk
        return disk
    
    def ssh_cpu(self): 
        cmd=self.powershell_path+'gwmi -computername localhost win32_Processor'
        res=self.ssh(cmd)
        res=res.split('No such file or directory')[-1].replace('\r','').split('\n')
        res=[r for r in res if r]
#        print res
        cpu={}
        for i in res:
#            print '='*10
#            print i
            i=i.split(':')
        #    print i
            if len(i)==2:
                key,value=i
            else:
                continue
            key=key.strip()
            value=value.strip()
#            print 'key:',key
#            print 'value:',value
            cpu[key]=value
        return cpu
    
    def ssh_memory(self):
        totalmem=self.powershell_path+'Get-WmiObject win32_OperatingSystem TotalVisibleMemorySize'
        freemem=self.powershell_path+'Get-WmiObject win32_OperatingSystem FreePhysicalMemory'
        memory={}
        for cmd in [totalmem,freemem]:
            res=self.ssh(cmd)
            if 'Win32_OperatingSystem' in res:
                res=res=res.replace('\r','').split('\n')
                res=[m for m in res if m][-1]
                print 'res:',res
                key,value=res.split(':')
                key=key.strip()
                value=value.strip()
                memory[key]=value
            else:
                print "not return data"
                return None
        return memory
    def ssh_ping(self,host):
        cmd='ping -n 1 %s'%host
        patt=r'.+?(\d*)% loss.*'
        res=self.ssh(cmd).replace('\r','').replace('\n','')
        print res
        m=re.match(patt,res)
        if m:
            lost_percent=m.group(1)
            print 'lost_percent:',lost_percent
            return int(lost_percent)
        else:
            return None
        
    def ssh_ps(self):
        cmd=self.powershell_path+'ps'
        res=self.ssh(cmd)
        ps=[]
        if '-- -----------' in res:
            res=res.replace('\r','').split('-- -----------')[-1].split('\n')
            res=[d for d in res if d.strip()]
            for p in res:
                process={}
                row=[para for para in p.split(' ') if para.strip()]
                process['handles']=row[0]
                process['npm']=row[1]
                process['pm']=row[2]
                process['ws']=row[3]
                process['vm']=row[4]
                process['cpu']=row[5]
                process['id']=row[6]
                process['process_name']=row[-1]
                ps.append(process)
#            print ps
            return ps
        else:
            return None
    def ssh_netstat(self):
        cmd='netstat -ao'
        res=self.ssh(cmd)
        netstat=[]
        if 'PID' in res:
            res=res.replace('\r','').split('PID')[-1].split('\n')
            res=[d for d in res if d.strip()]
            for p in res:
                process={}
                row=[para for para in p.split(' ') if para.strip()]
                process['proto']=row[0]
                process['local_address']=row[1]
                process['foreign_address']=row[2]
                process['state']=row[3]
                process['pid']=row[-1]
                netstat.append(process)
#            print netstat
            return netstat
        else:
            return None
if __name__ == "__main__":
    cmd="c:/WINDOWS/system32/WindowsPowerShell/v1.0/powershell.exe ps"
    user='admin'
    host='192.168.123.105'
    password='123456'
    ssh=ssh_win32(user,host,password,systemroot='c',timeout=5)
#    print ssh.ssh_cpu()
#    print "\n\n\n\n"
#    print ssh.ssh_disk()
#    print "\n\n\n\n"
#    print ssh.ssh_memory()
#    print ssh.ssh_ping(host)
#    print ssh.ssh_ps()
#    print ssh.ssh_netstat()
 

Author:pako

Email&gtalk:zealzpc@gmail.com

 

分享到:
评论

相关推荐

    python通过ssh-powershell监控windows的方法

    ### Python通过SSH-PowerShell监控Windows的方法 #### 概述 在IT运维领域,服务器监控是确保业务稳定运行的关键环节之一。与Linux相比,Windows服务器由于其不同的命令行环境(如CMD、PowerShell等),在进行自动...

    win10内置Linux运用python进行远程连接

    通过 Win10 内置 Linux,我们可以使用 Python 进行远程连接,实现远程服务器的管理和控制。在本文中,我们将详细介绍如何在 Win10 中启用内置 Linux,并使用 Python 进行远程连接。 一、启用 Win10 内置 Linux 要...

    海量系统日志采集解析实践.pdf

    同时,SFTP、Shell脚本(Python或Bat/Powershell)的运用,使得日志采集更加灵活,能够适应不同场景。 2. **横向扩容**:通过虚拟化集群的支持,可以实现日志处理能力的横向扩展,从而应对数据量激增的问题。 3. *...

    行业分类-设备装置-一种脚本生成方法及装置.zip

    不同的语言适用于不同的操作系统和应用场景,例如,bash脚本在Unix/Linux环境中广泛使用,而PowerShell则在Windows系统中更为常见。 2. 自动化工具:有许多工具可以帮助我们自动生成脚本,如Ansible、Chef、Puppet...

    海量系统日志采集解析实践.pptx

    此外,SF TPSFTP、Shell、Python或Bat/Powershell脚本可以用来自动化处理特定场景下的日志采集任务。 在日志的过滤、转换和富化阶段,原始日志经过负载均衡处理后,进行必要的预处理工作,包括去除无用信息、统一...

    2023年《网络建设与运维》国赛脚本文件及导出答案视频

    在实际操作中,脚本语言如Python、Bash或PowerShell等,可以用于批量处理网络任务,如批量配置网络设备、监控网络状态、自动化报告生成等。在竞赛中,利用脚本文件导出答案,可能是对参赛者在短时间内处理大量数据和...

    网站和工具:分类收藏一些网站,工具和软件,记录一些关于WindowsmacOSlinux系统的使用技巧和软件操作

    例如,通过 Wine 或 Parallels 在macOS和Linux上运行Windows应用程序,或者使用VNC、SSH在远程计算机上操控桌面。 总之,无论是Windows、macOS还是Linux用户,熟练掌握操作系统特性,了解并运用各种工具,结合不断...

    运维实践指南

    介绍在Windows操作系统环境下,如何配置和管理服务,例如使用PowerShell脚本或管理工具来设置和维护。 ### 技术实践 对于在技术社区参与和贡献的过程,书中介绍了如何使用版本控制系统Git进行版本控制和协同开发,...

    终端机

    在Windows系统中,用户可能会使用PowerShell或旧版的Command Prompt。 终端机的使用包括但不限于以下几个方面: 1. **文件和目录管理**:通过命令如`ls`(列出目录内容)、`cd`(切换目录)、`mkdir`(创建目录)...

    ForJenkins:詹金斯(Henry)硬件课程

    这通常涉及使用脚本语言(如bash、Python或PowerShell)编写部署脚本。 9. **错误处理与通知**:学习如何设置Jenkins的错误处理机制,当构建失败时发送通知,如邮件、短信或Slack消息,确保开发团队能及时获取反馈...

    scripts_for_useful_tools_installations:安装有用工具的脚本

    这些脚本可能是用各种编程语言如bash、Python或PowerShell编写的,适用于Linux、Unix或Windows等操作系统。 描述中提到的“安装有用工具的脚本”可能涵盖了广泛的功能,包括但不限于系统优化工具、开发环境、版本...

Global site tag (gtag.js) - Google Analytics