原文出处:
- 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
- $ sudo apt-get install python-paramiko
Or install from source
- $ wget http://www.lag.net/paramiko/download/paramiko-1.7.6.tar.gz
- $ tar xzf paramiko-1.7.6.tar.gz
- $ cd paramiko-1.7.6
- $ python setup.py build
- $ su -c "python setup.py install"
Working with paramiko
SSHClient是paramkio模块提供的主要的类。它提供了基础的可以用来实例化服务器连接的接口。下面的代码创建了一个新的SSHClient对象,然后调用“connect()”来连接到我们本地的SSH服务器。
- import paramiko
- ssh = paramiko.SSHClient()
- ssh.connect('192.168.1.2', username='vinod', password='screct')
另一种方法是使用SSH密钥的
- import paramiko
- ssh = paramiko.SSHClient()
- ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
- ssh.connect('beastie', username='vinod', password='secret')
- stdin, stdout, stderr = ssh.exec_command('df -h')
- print stdout.readlines()
- ssh.close()
“paramiko.AutoAddPolicy()”方法将自动接受未知密钥
使用sudo命令运行:
- import paramiko
- cmd = "sudo /etc/rc.d/apache2 restart"
- ssh = paramiko.SSHClient()
- ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
- ssh.connect('beastie', username='vinod', password='secret')
- stdin, stdout, stderr = ssh.exec_command(cmd)
- stdin.write('secret\n')
- stdin.flush()
- print stdout.readlines()
- ssh.close()
使用 SFTPClient 实现文件安全传输
SFTPClient用来打开一个sftp 会话在一个开放的ssh中传输和执行远程文件的操作。
首先我们创建一个连接:
- import paramiko
- import os
- privatekeyfile = os.path.expanduser('~/.ssh/id_rsa')
- mykey = paramiko.RSAKey.from_private_key_file(privatekeyfile)
- username = 'vinod'
- transport.connect(username = username, pkey = mykey)
上面应该少了一句代码:transport = paramiko.Transport((“主机”,”端口”))
创建socket对象
现在我们开始SFTP客户端:
- sftp = paramiko.SFTPClient.from_transport(transport)
现在推送文件到远程系统:
- remotepath='/var/www/p_w_picpaths/file.png'
- localpath='/tmp/file.png'
- sftp.put(remotepath, localpath)
最后,关闭SFTP连接:
- sftp.close()
- transport.close()
创建paramiko.Transport对象可以用socket也可以用IP,port
- import paramiko
- transport = paramiko.Transport(('localhost',22))
- transport.connect(username='root', password = 'password')
- sftp = paramiko.SFTPClient.from_transport(transport)
- sftp.get(remotefile,localfile)
- #如果是上传则用:
- #sftp.put(localfile, remotefile)
- transport.close()
- #用socket连接
- tcpsock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
- tcpsock.settimeout(5)
- tcpsock.connect((ip,22),)
- ssh = paramiko.Transport(tcpsock)
- ssh.connect(username=user,password=password)
- sftpConnect=paramiko.SFTPClient.from_transport(ssh)