进程完成后Plink.exe不会关闭。尝试通过检查输出=='来尝试打破while循环时,代码卡住了。 ':休息,但仍然没有运气。我能够打印实时输出,但在完成后无法打破循环。
#Establish ssh connection to a server
def _establish_connection(self):
connection='plink -ssh {}@{} -pw {}'.format(self.user,self.server,self.pw)
self.sp = Popen(connection,stdin=PIPE,stdout=PIPE)
#Trying to read live output from stdout and write to file
def _test_create_log(self,_system,_logdir):
self._establish_connection()
self.sp.stdin.write(_command)
timestr = time.strftime("%Y%m%d-%H%M%S")
dir_to_log = os.path.join(_logdir,_system + '_' + timestr + '.txt')
with open(dir_to_log,'w+') as myLog:
while True:
output = self.sp.stdout.readline()
output.decode('ASCII')
if output != '':
myLog.write(output)
print(output.strip())
else: #Code does not reach here, plink not killed.
self.sp.kill()
break
答案 0 :(得分:1)
Shell是一个带输入和输出的黑盒子。无法检测到某个特定命令的输出已结束。你所能做的就是在输出的末尾添加一些魔术字符串并寻找它。无论如何,这不是正确的解决方案。
如果要使用命令关闭Plink,请在Plink命令行上提供命令,如:
connection='plink -ssh {}@{} -pw {} {}'.format(self.user,self.server,self.pw,_command)
虽然更好的方法是在Python中使用本机SSH库,例如Paramiko,而不是驱动外部控制台应用程序。