没有得到paramiko / ssh命令的输出

时间:2010-06-15 21:19:06

标签: python ssh paramiko

我正在使用paramiko / ssh / python尝试在远程服务器上运行命令。当我手动ssh并运行有问题的命令时,我得到了我想要的结果。但是,如果我使用下面的python(从本网站上的另一个线程中选择),则没有返回的数据。如果我将命令修改为更基本的命令,如'pwd'或'ls',我就可以得到输出。任何帮助表示赞赏。

谢谢, 马特

import paramiko  
import time  
import sys, os, select  
import select  
hostname='10.15.27.166'  
hostport=22  
cmd='tail -f /x/web/mlog.txt' #works  
#cmd='customexe -args1 -args2' #doesn't work  
client = paramiko.SSHClient()  
client.load_system_host_keys()  
client.connect(hostname=hostname, username=username, password=password)  
transport = client.get_transport()  
channel = transport.open_session()  
channel.exec_command(cmd)  
while True:  
  rl, wl, xl = select.select([channel],[],[],0.0)  
  if len(rl) > 0:  
    # Must be stdout  
    print channel.recv(1024)  
  time.sleep(1)

1 个答案:

答案 0 :(得分:1)

我找到了一个修复程序,但不一定是根本原因:当paramiko创建ssh连接时,它没有在远程服务器上的主目录中运行我的bash_profile。因此,我将bash_profile中的命令复制到cmd变量中,从而加载了我认为会自动加载的各种环境变量。然后命令“customexe ...”按预期返回输出。