2010-06-22 9 views
24

Ho installato e scritto il seguente Paramiko che non è in grado di mettere il file. È facilmente in grado di 'ottenere' un file ed eseguire comandi 'ls' su di esso.'Put' in SFTP usando PAramiko

#set username & password 
username='runaway' 
password='runaway' 
port=22 
source= '/Unzip.sh' 
destination ='/var/mpx/www/http' 


#SFTP 
client.load_system_host_keys() 
print " hostname =%s \n username=%s \n password=%s \n" (hostname,username,password) 
t = paramiko.Transport((hostname, port)) 
t.connect(username=username,password=password) 
sftp = paramiko.SFTPClient.from_transport(t) 
sftp.put(source,destination) 
#sftp.close() 
#t.close() 

Utilizzando un comando 'mettere' dà il seguente errore & dello stack trace -

File "upload_file.py", line 84, in ? 
    sftp.put(source,destination) 
    File "/usr/lib/python2.4/site-packages/paramiko/sftp_client.py", line 522, in put 
    fr = self.file(remotepath, 'wb') 
    File "/usr/lib/python2.4/site-packages/paramiko/sftp_client.py", line 221, in open 
    t, msg = self._request(CMD_OPEN, filename, imode, attrblock) 
    File "/usr/lib/python2.4/site-packages/paramiko/sftp_client.py", line 572, in _request 
    return self._read_response(num) 
    File "/usr/lib/python2.4/site-packages/paramiko/sftp_client.py", line 619, in _read_response 
    self._convert_status(msg) 
    File "/usr/lib/python2.4/site-packages/paramiko/sftp_client.py", line 649, in _convert_status 
    raise IOError(text) 
IOError: Failure 

Come faccio a superare questo?

risposta

51

La soluzione mi è sembrata molto divertente!

source= '/Unzip.sh' 
destination ='/var/mpx/www/http/Unzip.sh' 

Appena modificato il percorso di destinazione per includere anche il nome del file. Non mi aspettavo un errore come questo proveniente da un pacchetto Python.

+0

si potrebbe forse cerotto paramiko in tal senso;) vale a dire quindi capisce le cartelle di destinazione. evviva – nuts

0

Questo si verifica anche in 2.0.2 quando si tenta di sftp.mkdir('/exists'):

Traceback (most recent call last): 
    ... 
    File "/usr/local/lib/python2.7/site-packages/paramiko/sftp_client.py", line 380, in mkdir 
    self._request(CMD_MKDIR, path, attr) 
    File "/usr/local/lib/python2.7/site-packages/paramiko/sftp_client.py", line 730, in _request 
    return self._read_response(num) 
    File "/usr/local/lib/python2.7/site-packages/paramiko/sftp_client.py", line 781, in _read_response 
    self._convert_status(msg) 
    File "/usr/local/lib/python2.7/site-packages/paramiko/sftp_client.py", line 811, in _convert_status 
    raise IOError(text) 
IOError: Failure 

Questo era il mio Python 2.7.9 fix:

try: 
    sftp.mkdir(remote_dir) 
except IOError: 
    logging.debug('%s already exists.', remote_dir)