Python中使用SSH需要用到OpenSSH,而OpenSSH依賴於paramiko模組,而paramiko模組又依賴於pycrypto模組,因此要在Python中使用SSH,則需要先安裝模組順序是:pycrypto -> ecdsa -> paramiko
1、安裝pyCrypto
安裝這個比較麻煩,需要本地編譯,要裝vs或gcc還有一堆配置,還不一定能編譯成功。(網上能搜到安裝步驟)
建議直接下載已編譯版: http://www.voidspace.org.uk/python/modules.shtml#pycrypto
直接下載並安裝既可。
(註:crypto有java和C++版)
2、安裝ecdsa
看很多部落格沒有提到這個庫,但我執行paramiko時,提示找不到ecdsa模組。
下載:https://pypi.python.org/pypi/ecdsa/0.9 ,解壓到一個目錄,目錄中有一個setup.py。
安裝比較簡單,windows下直接在剛才解壓後的目錄執行:python setup.py install
3.安裝paramiko
與安裝ecdsa類型,只是開啟下載頁面很慢。。。
下載: https://github.com/paramiko/paramiko#,
安裝步驟同ecdsa
註:1、所有另外安裝的第三方庫,如果不特指定安裝後庫目錄的話,將預設儲存到 %PYTHON_HOME%\Lib\site-packages下。
2、python大小寫敏感,對模組名也是。
3、Crypto可以提供常見的加解密演算法,如:RSA、RC4、DSA、DES
測試代碼:
代碼如下:
#!/usr/bin/python
# -*- coding:utf-8 -*-
# cp@chenpeng.info
import paramiko
def MAIN():
host = “10.1.1.1″
port = 22
user = “root”
pswd = “111222333″
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(host, port, user, pswd)
stdin, stdout, stderr = ssh.exec_command(‘ifconfig')
print stdout.read()
ssh.close()
#
if __name__=='__main__':
try:
MAIN()
except Exception,e:
print e
輸出如下:
目前主要用於批量執行多個伺服器的ssh命令,批量維護比較方便。
下面是兩種使用paramiko串連到linux伺服器的代碼
方式一:
代碼如下:
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect("某IP地址",22,"使用者名稱", "口令")
上面的第二行代碼的作用是允許串連不在know_hosts檔案中的主機
方式二:
代碼如下:
t = paramiko.Transport(("主機","連接埠"))
t.connect(username = "使用者名稱", password = "口令")
如果串連遠程主機需要提供密鑰,上面第二行代碼可改成:
代碼如下:
t.connect(username = "使用者名稱", password = "口令", hostkey="密鑰")
例子:
代碼如下:
#!/usr/bin/python
import paramiko
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect("某IP地址",22,"使用者名稱", "口令")
stdin, stdout, stderr = ssh.exec_command("你的命令")print stdout.readlines()
ssh.close()
下載linux伺服器上的檔案
代碼如下:
#!/usr/bin/python
import paramiko
t = paramiko.Transport(("主機","連接埠"))
t.connect(username = "使用者名稱", password = "口令")
sftp = paramiko.SFTPClient.from_transport(t)
remotepath='/var/log/system.log'
localpath='/tmp/system.log'
sftp.get(remotepath, localpath)
t.close()
上傳檔案到linux伺服器
代碼如下:
#!/usr/bin/python
import paramiko
t = paramiko.Transport(("主機","連接埠"))
t.connect(username = "使用者名稱", password = "口令")
sftp = paramiko.SFTPClient.from_transport(t)
remotepath='/var/log/system.log'
localpath='/tmp/system.log'
sftp.put(localpath,remotepath)
t.close()