分享

Python 利用pexpect和paramiko模块进行远程服务器的监控

坎蒂丝_Swan 发表于 2015-1-14 11:19:59 [显示全部楼层] 回帖奖励 阅读模式 关闭右栏 0 39007
问题导读
1.Python怎样实现对远程服务器进行监控?
2.pexpect模块和paramiko模块,如何进行多台远程服务器的监控?








一 模块的安装
   安装pexpect模块
        pip install pexpect
    安装paramiko模块
        yum install python-devel
        pip install paramiko
        注意:如果不安装python-devel,则会报
        error: command ‘gcc’ failed with exit status 1;这是因为缺少python-dev的软件包
二 代码示例   
       pexpect代码示例   

  1. #!/usr/bin/python
  2. # encoding=utf-8
  3. # Filename: pexpect_test.py
  4. import pexpect
  5. def sshCmd(ip, passwd, cmd):
  6.     ret = -1
  7.     ssh = pexpect.spawn('ssh root@%s "%s"' % (ip, cmd))
  8.     try:
  9.         i = ssh.expect(['password:', 'continue connecting(yes/no)?'], timeout=5)
  10.         if i == 0:
  11.             ssh.sendline(passwd)
  12.         elif i == 1:
  13.             ssh.sendline('yes\n')
  14.             ssh.expect('password:')
  15.             ssh.sendline(passwd)
  16.         ssh.sendline(cmd)
  17.         r = ssh.read()
  18.         print r
  19.         ret = 0
  20.     except pexpect.EOF:
  21.         print "EOF"
  22.         ret = -1
  23.     except pexpect.TIMEOUT:
  24.         print "TIMEOUT"
  25.         ret = -2
  26.     finally:
  27.         ssh.close()
  28.     return ret
  29. sshCmd('xxx.xxx.xxx.xxx','xxxxxx','ls /root')
复制代码
paramiko代码示例
注意:必须要增加client.load_system_host_keys()此句,否则报如下错误:
unbound method missing_host_key() must be called with AutoAddPolicy instance as first argument (got SSHClient instance instead)

  1. #!/usr/bin/python
  2. # encoding=utf-8
  3. # Filename: paramiko_test.py
  4. import datetime
  5. import threading
  6. import paramiko
  7. def sshCmd(ip, username, passwd, cmds):
  8.     try:
  9.         client = paramiko.SSHClient()
  10.         client.load_system_host_keys()
  11.         client.set_missing_host_key_policy(paramiko.AutoAddPolicy)
  12.         client.connect(ip, 22, username, passwd, timeout=5)
  13.         for cmd in cmds:
  14.             stdin, stdout, stderr = client.exec_command(cmd)
  15.             lines = stdout.readlines()
  16.             # print out
  17.             for line in lines:
  18.                 print line,
  19.         print '%s\t 运行完毕\r\n' % (ip)
  20.     except Exception, e:
  21.         print '%s\t 运行失败,失败原因\r\n%s' % (ip, e)
  22.     finally:
  23.         client.close()
  24. #上传文件      
  25. def uploadFile(ip,username,passwd):
  26.     try:
  27.         t=paramiko.Transport((ip,22))
  28.         t.connect(username=username,password=passwd)
  29.         sftp=paramiko.SFTPClient.from_transport(t)
  30.         remotepath='/root/main.py'
  31.         localpath='/home/data/javawork/pythontest/src/main.py'
  32.         sftp.put(localpath,remotepath)
  33.         print '上传文件成功'
  34.     except Exception, e:
  35.         print '%s\t 运行失败,失败原因\r\n%s' % (ip, e)
  36.     finally:
  37.         t.close()
  38. #下载文件
  39. def downloadFile(ip,username,passwd):
  40.     try:
  41.         t=paramiko.Transport((ip,22))
  42.         t.connect(username=username,password=passwd)
  43.         sftp=paramiko.SFTPClient.from_transport(t)
  44.         remotepath='/root/storm-0.9.0.1.zip'
  45.         localpath='/home/data/javawork/pythontest/storm.zip'
  46.         sftp.get(remotepath,localpath)
  47.         print '下载文件成功'
  48.     except Exception, e:
  49.         print '%s\t 运行失败,失败原因\r\n%s' % (ip, e)
  50.     finally:
  51.         t.close()  
  52.          
  53. if __name__ == '__main__':
  54.     # 需要执行的命令列表
  55.     cmds = ['ls /root', 'ifconfig']
  56.     # 需要进行远程监控的服务器列表
  57.     servers = ['xxx.xxx.xxx.xxx']
  58.       
  59.     username = "root"
  60.     passwd = "xxxxxx"
  61.     threads = []
  62.     print "程序开始运行%s" % datetime.datetime.now()
  63.     # 每一台服务器创建一个线程处理
  64.     for server in servers:
  65.         th = threading.Thread(target=sshCmd, args=(server, username, passwd, cmds))
  66.         th.start()
  67.         threads.append(th)
  68.          
  69.     # 等待线程运行完毕
  70.     for th in threads:
  71.         th.join()
  72.          
  73.     print "程序结束运行%s" % datetime.datetime.now()
  74.      
  75.     #测试文件的上传与下载
  76.     uploadFile(servers[0],username,passwd)
  77.     downloadFile(servers[0],username,passwd)
复制代码






欢迎加入about云群90371779322273151432264021 ,云计算爱好者群,亦可关注about云腾讯认证空间||关注本站微信

没找到任何评论,期待你打破沉寂

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

推荐上一条 /2 下一条