尚观 python获取服务器性能

最近在学习python,首先学习一下性能指标的监控,平时做性能测试都是在服务器上部署测试脚本进行监控,比较麻烦,现在有了这个脚本就可以直接抓取远程的性能指标写到报告中
#!/usr/bin/python
#coding:utf-8
import paramiko,string,time
remote_m = [
# db server
('10.10.10.29', 'zhanghao', '!QAZ@WSX3edc'),
# tomcat
('10.10.10.30', 'zhanghao', '!QAZ@WSX3edc')
]
def getCpuLoad(host, user, pwd):
cmd='uptime |awk \'{print $10 $11 $12}\''
#cmd='top -n 1'
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(host,22,user, pwd)
stdin, stdout, stderr = ssh.exec_command(cmd)
load_info=stdout.readlines()
erro_info=stderr.readlines()
erro_message=('erro_messag: %s' %erro_info + '\n')
sStr1=string.join(load_info)
#load_info = sStr1[sStr1.index('average')+9:len(sStr1)]
return sStr1

ssh.colse()

if __name__ == "__main__":

report_name = 'report_' + time.strftime('%Y%m%d%H%M',time.localtime(time.time())) + '.rpt'
debug_name = 'default.debug'
report_file = open('./reports/' + report_name, 'a')
debugfile = open(debug_name, 'a')
print 'benchmark start, generate report:' + report_name
report_file.write('start at ' + time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())) + '\n')

for m in remote_m:
print ('%s load: %s' %(m[0], getCpuLoad(m[0], m[1], m[2])))
report_file.write('%s load: %s' %(m[0], getCpuLoad(m[0], m[1], m[2])))


使用shell调用测试结果

#/bin/bash
python /home/shell/python_log/test.py
echo "执行成功"
~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值