频道栏目
首页 > 程序开发 > Web开发 > Python > 正文
python获取服务器性能
2012-11-21 09:34:02           
收藏   我要投稿

最近在学习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 "执行成功"
~                   

点击复制链接 与好友分享!回本站首页
相关TAG标签 性能 服务器
上一篇:python实现C#中类似于AutoResetEvent类的阻塞模式
下一篇:扫描端口
相关文章
图文推荐
文章
推荐
点击排行

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站