python通过ssh-powershell监控windows的方法
作者:niuniu 发布时间:2021-07-24 03:55:16
标签:python,ssh-powershell,windows
本文实例讲述了python通过ssh-powershell监控windows的方法。分享给大家供大家参考。具体分析如下:
对于服务器的监控来说,监控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 -*-
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()
希望本文所述对大家的Python程序设计有所帮助。


猜你喜欢
- 在上一篇文章《深入理解 go Mutex》中, 我们已经对 go Mutex 的实现原理有了一个大致的了解,也知道了 Mutex 可以实现并
- 有时候,我们需要将TensorFlow的模型导出为单个文件(同时包含模型架构定义与权重),方便在其他地方使用(如在c++中部署网络)。利用t
- 磁盘突然报错使用率过大,排查原因,发现mysql的binlog文件占用过大命令ls -l -hmysql-binlog是MySQL数据库的二
- python框架有很多,例如:Flask,Django,FastAPI 等。本文将使用 Flask 来编写 API 接口。安装Flask首先
- 这篇文章主要介绍了wxpython自定义下拉列表框过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要
- 一、参数和共享引用:In [56]: def changer(a,b): ....: a=2 ....
- 一、为什么要分库分表如果一个网站业务快速发展,那这个网站流量也会增加,数据的压力也会随之而来,比如电商系统来说双十一大促对订单数据压力很大,
- 布尔类型是PHP中 最简单的类型。它的值可以为 TRUE 或 FALSE。如:$foo=false;$foo1=true;echo &quo
- 原始需求:例如有一个列表:l = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]希望把它转换成下面这种形式:[1, 2,
- 找到工具》选项》Designers》表设计器和数据库设计器 然后将“阻止保存要求重新创建表的更改” 的这一项的钩钩去掉就OK了
- python中日期类datetime功能比较强大,使用起来很方便,把常用的两种用法总结如下:from datetime import dat
- 页面是这样的我尝试了很多次,都不响应。代码是这样的import xlrd###导入数据def read_data(workboo
- 函数嵌套和嵌套调用函数的嵌套函数的嵌套:在函数里面还有函数。分为外函数和内函数。嵌套函数是为函数内部服务的,比如减少代码的重复,想要调用函数
- 这小节我们要介绍Go里面的流程控制以及函数操作。流程控制流程控制在编程语言中是最伟大的发明了,因为有了它,你可以通过很简单的流程描述来表达很
- 本文实例总结了Python实现判断一个字符串是否包含子串的方法。分享给大家供大家参考,具体如下:1.使用成员操作符 in>>&g
- enumerate首先介绍的是enumerate函数。在我们日常编程的过程当中,经常会遇到一个问题。在C语言以及一些古老的语言当中是没有迭代
- 上篇更新到pygame实现俄罗斯方块游戏(AI篇2) ,原本应该继续做优化,不过考虑到完成游戏完整性,这张就先把对战做好。一、对战的方块管理
- 一、js--->单线程 严格意义上来说,javascript没有多线程的概念,所有的程序都是单线程依次执行的。1、什么是单线
- 本文实例讲述了ThinkPHP中url隐藏入口文件后接收alipay传值的方法。分享给大家供大家参考。具体方法如下:现在公司项目的需求变化多
- python中函数参数是引用传递(不是值传递)。对于不可变类型,因变量不能被修改,所以运算时不会影响到变量本身;而对于可变类型来说,函数体中