如何等待我的远程脚本完成,这是由paramiko模块触发的

时间:2017-07-08 15:59:13

标签: python multithreading paramiko

我试图在远程计算机上执行python脚本 远程命令需要1分钟才能完成[这是一个python脚本,只需在循环中打印]

我看到我的线程抛出命令并立即出来。 我希望我的线程等到远程脚本完成。

有没有办法呢?

class Thread_cls(threading.Thread):
def __init__(self,tid,tname,ip,script):
    threading.Thread.__init__(self)
    print 'kkk'
    self.thread_id=tid
    self.thread_name=tname
    self.ip=ip
    self.script=script
def run(self):

    print "ENTERED HERE"
    stdin,stdout,stderr=self.connect_to_linux_vm(self.ip).exec_command(self.script)
    exit_status = stdout.channel.recv_exit_status()
    print "out of ssh command"
    #pass
def connect_to_linux_vm(self,ip,uname=None,password=None):
    ssh_linux = paramiko.SSHClient()
    ssh_linux.set_missing_host_key_policy(
    paramiko.AutoAddPolicy())

    ssh_linux.connect(ip, username=uname,
            password=pwd)

    return ssh_linux



obj1=Thread_cls(1,'T1','x.x.x.x',"python TEST.py")
obj1.start()
obj1.join()

1 个答案:

答案 0 :(得分:1)

更改行

stdin, stdout, stderr = self.connect_to_linux_vm(self.ip).exec_command(self.script)

分为两行:

ssh = self.connect_to_linux_vm(self.ip)
stdin, stdout, stderr = ssh.exec_command(self.script)

否则从SSHClient返回的connect_to_linux_vm()对象在调用exec_command()后会立即销毁,因为还没有其他vars引用它。