原文出处:

   
   
   
   
  1. http://segfault.in/2010/03/paramiko-ssh-and-sftp-with-python/ 

Paramiko  是一个用于python2.5或更高版本的实现了使用SSH2协议安全(加密与验证)的连接远程计算机的模块 

重点是使用作为替代SSL的SSH2在python脚本间创建连接。支持所有的主流运算与哈希模块。同样也支持SFTP服务端模式与客户端模式

 

安装 paramiko

First, we need to install paramiko, if you don’t have it already.

On Ubuntu/Debian

 

   
   
   
   
  1. $ sudo apt-get install python-paramiko 

Or install from source

   
   
   
   
  1. $ wget http://www.lag.net/paramiko/download/paramiko-1.7.6.tar.gz 
  2. $ tar xzf paramiko-1.7.6.tar.gz 
  3. $ cd paramiko-1.7.6 
  4. $ python setup.py build 
  5. $ su -c "python setup.py install" 

 

Working with paramiko

SSHClient是paramkio模块提供的主要的类。它提供了基础的可以用来实例化服务器连接的接口。下面的代码创建了一个新的SSHClient对象,然后调用“connect()”来连接到我们本地的SSH服务器。

   
   
   
   
  1. import paramiko 
  2. ssh = paramiko.SSHClient() 
  3. ssh.connect('192.168.1.2', username='vinod', password='screct'

另一种方法是使用SSH密钥的

   
   
   
   
  1. import paramiko 
  2.   
  3. ssh = paramiko.SSHClient() 
  4. ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) 
  5. ssh.connect('beastie', username='vinod', password='secret'
  6. stdin, stdout, stderr = ssh.exec_command('df -h'
  7. print stdout.readlines() 
  8. ssh.close() 

“paramiko.AutoAddPolicy()”方法将自动接受未知密钥

使用sudo命令运行:

   
   
   
   
  1. import paramiko 
  2.   
  3. cmd    = "sudo /etc/rc.d/apache2 restart" 
  4.   
  5. ssh    = paramiko.SSHClient() 
  6. ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) 
  7. ssh.connect('beastie', username='vinod', password='secret'
  8. stdin, stdout, stderr = ssh.exec_command(cmd) 
  9. stdin.write('secret\n'
  10. stdin.flush() 
  11. print stdout.readlines() 
  12. ssh.close() 

 

使用 SFTPClient 实现文件安全传输

 

SFTPClient用来打开一个sftp 会话在一个开放的ssh中传输和执行远程文件的操作。

首先我们创建一个连接:

   
   
   
   
  1. import paramiko 
  2. import os 
  3. privatekeyfile = os.path.expanduser('~/.ssh/id_rsa'
  4. mykey = paramiko.RSAKey.from_private_key_file(privatekeyfile) 
  5. username = 'vinod' 
  6. transport.connect(username = username, pkey = mykey) 

上面应该少了一句代码:transport = paramiko.Transport((“主机”,”端口”))

创建socket对象

现在我们开始SFTP客户端:

   
   
   
   
  1. sftp = paramiko.SFTPClient.from_transport(transport) 

现在推送文件到远程系统:

   
   
   
   
  1. remotepath='/var/www/p_w_picpaths/file.png' 
  2. localpath='/tmp/file.png' 
  3. sftp.put(remotepath, localpath) 

最后,关闭SFTP连接:

   
   
   
   
  1. sftp.close() 
  2. transport.close() 

创建paramiko.Transport对象可以用socket也可以用IP,port

 

   
   
   
   
  1. import paramiko 
  2.  
  3. transport = paramiko.Transport(('localhost',22)) 
  4. transport.connect(username='root', password = 'password'
  5. sftp = paramiko.SFTPClient.from_transport(transport) 
  6. sftp.get(remotefile,localfile) 
  7. #如果是上传则用: 
  8. #sftp.put(localfile, remotefile) 
  9. transport.close() 
  10.  
  11. #用socket连接 
  12. tcpsock = socket.socket(socket.AF_INET,socket.SOCK_STREAM) 
  13. tcpsock.settimeout(5
  14. tcpsock.connect((ip,22),) 
  15. ssh = paramiko.Transport(tcpsock) 
  16. ssh.connect(username=user,password=password) 
  17. sftpConnect=paramiko.SFTPClient.from_transport(ssh)