要求:root密码都一样,提前建好一个存放IP的文件
#vim /home/remote_ssh.py
#!/usr/bin/env python
import sys #定义执行程序需要几个参数的模块 import paramiko #远程ssh import os #判断文件是否存在的模块 import getpass #让用户输入密码的模块 import threading #多线程模块
def remote_ssh(host,pwd,comm): ssh = paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) #回答yes ssh.connect(host,username='root',password=pwd) stdin,stdout,stderr = ssh.exec_command(comm) out = stdout.read() #定义标准输出 err = stderr.read() #定义错误输出 if out: print "Host {0} output is:\n{1}".format(host,out) if err: print "Host {0} error is:/n{1}".format(host,err) ssh.close()
if name == 'main': if len(sys.argv) != 3: #sys.argv表示包含程序在内的参数个数 print "Usage:{0} ipfile 'command'".format(sys.argv[0]) sys.exit(1) if not os.path.isfile(sys.argv[1]): #如果IP文件不存在 print "No such file:",sys.argv[1] sys.exit(2)
passwd = getpass.getpass("Please input password:")
ipfile = sys.argv[1]
command = sys.argv[2]
with open(ipfile) as fileobj:
for line in fileobj:
ip = line.strip()
t = threading.Thread(target=remote_ssh,args=(ip,passwd,command))
t.start()
#python /home/remote_ssh.py /home/ipaddr.txt 'echo 88888888 | passwd --stdin root' #修改root密码为88888888