darkpoon 发表于 2018-8-3 11:29:06

[Python]用python实现批量/并发处理

  最近在学习python,感觉很不错,特别是实现批量/并发处理。实现起来非常方便,比shell方便很多。刚学python一个月,在这留个记录。下面分享一段代码。多提建议/意见~(QQ群交流:24967504)
  需求:批量查看/对比线上服务器的状态情况,如uptime、df -h、MD5sum文件等等。本打算让执行命令通过传参进行、密码通过交互输入(3次不对退出)。后面再完善~~
  #-*- coding: utf-8 -*-
  #!/usr/bin/python
  import paramiko
  import threading
  def ssh2(ip,username,passwd,cmd):
  try:
  ssh = paramiko.SSHClient()
  ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
  ssh.connect(ip,22,username,passwd,timeout=5)
  for m in cmd:
  stdin,stdout,stderr = ssh.exec_command(m)
  stdin.write("Y")
  out = stdout.readlines()
  for o in out:
  print o,
  print '%s' %(ip),
  print '========================================================================='
  ssh.close()
  except:
  print '%s' %(ip),
  print '========================================================================='
  def main():
  cmd = ['uptime']#执行命令
  username = "root"
  passwd = "密码"
  threads =
  f = file('list.txt')#ip列表
  while True:
  ip = f.readline()
  if len(ip) == 0:
  break
  a = threading.Thread(target=ssh2,args=(ip,username,passwd,cmd))
  a.start()
  f.close()
  if __name__ == '__main__':
  main()
  执行结果:
  # python ssh2.py
  13:31:28 up 514 days,7:28,1 user,load average: 10.27, 9.44, 9.03
  192.168.13.116
  =========================================================================
  13:31:28 up 514 days,8:04,1 user,load average: 5.99, 6.05, 6.46
  192.168.13.117
  =========================================================================
页: [1]
查看完整版本: [Python]用python实现批量/并发处理