原文出處:
- 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)