Paramiko: SSH and SFTP With Python
原文出处:[*]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/images/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)
页:
[1]