借助Paramiko通過Python實(shí)現(xiàn)linux遠(yuǎn)程登陸及sftp的操作
paramiko是一個用于做遠(yuǎn)程控制的模塊,使用該模塊可以對遠(yuǎn)程服務(wù)器進(jìn)行命令或文件操作,paramiko是用python語言寫的一個模塊,遵循SSH2協(xié)議,支持以加密和認(rèn)證的方式,進(jìn)行遠(yuǎn)程服務(wù)器的連接。
由于使用的是python這樣的能夠跨平臺運(yùn)行的語言,所以所有python支持的平臺,如Linux, Solaris, BSD, MacOS X, Windows等,paramiko都可以支持,因此,如果需要使用SSH從一個平臺連接到另外一個平臺,進(jìn)行一系列的操作時,paramiko是最佳工具之一。
本文重點(diǎn)給大家介紹借助Paramiko通過Python實(shí)現(xiàn)linux遠(yuǎn)程登陸及sftp操作。
1. 使用shell命令
$ sshpass -p ${passwd} ssh -p ${port} -l ${user} -o StrictHostKeyChecking=no xx.xx.xx.xx 'ls -l'
然后你會發(fā)現(xiàn),你的輸出有很多你并不需要,但是又不去不掉的一些信息。對于shell 命令,可以直接使用管道,或者將標(biāo)準(zhǔn)輸出重定向到文件的方法取得執(zhí)行結(jié)果。
2. 使用 subprocess
通過Python可以想到使用 os.popen,os.system,commands,subprocess 等一些命令執(zhí)行庫來間接獲取系統(tǒng)信息 。這些庫獲取的 output 不僅有標(biāo)準(zhǔn)輸出,還包含標(biāo)準(zhǔn)錯誤信息。所以每次都要對 output 進(jìn)行數(shù)據(jù)清理,然后整理格式化,才能得到我們想要的數(shù)據(jù)。
import subprocess ssh_cmd = 'sshpass -p ${passwd} ssh -p 22 -l root -o StrictHostKeyChecking=no xx.xx.xx.xx ’ls -l’' status, output = subprocess.getstatusoutput(ssh_cmd) # 數(shù)據(jù)清理
總之,間接使用ssh命令的幾個問題:
需要額外安裝 sshpass(如果不免密的話)干擾信息太多,數(shù)據(jù)清理、格式化相當(dāng)麻煩代碼實(shí)現(xiàn)不夠優(yōu)雅,可讀性太差ssh 連接不能復(fù)用,一次連接僅能執(zhí)行一次命令代碼無法全平臺,僅能在 Linux 和 OSX 上使用
3. 使用Paramiko
安裝
python3 -m pip install paramiko
方法1:基于用戶名和密碼的 sshclient 方式登錄
該方法無法復(fù)用ssh連接。
import paramiko ssh = paramiko.SSHClient() # 允許連接不在know_hosts文件中的主機(jī) ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) # 建立連接 ssh.connect('xx.xx.xx.xx', username='root', port=22, password='you_password') # 使用這個連接執(zhí)行命令 ssh_stdin, ssh_stdout, ssh_stderr = ssh.exec_command('ls -l') # 獲取輸出 print(ssh_stdout.read()) # 關(guān)閉連接 ssh.close()
方法2:基于用戶名和密碼的 transport 方式登錄
該方法可以復(fù)用連接。
import paramiko # 建立連接 trans = paramiko.Transport(('xx.xx.xx.xx', 22)) trans.connect(username='root', password='you_passwd') ssh = paramiko.SSHClient() ssh._transport = trans ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh_stdin, ssh_stdout, ssh_stderr = ssh.exec_command('ls -l') print(ssh_stdout.read()) # 關(guān)閉連接 trans.close()
方法3:基于公鑰的 SSHClient 方式登錄
該方法無法復(fù)用ssh連接。
import paramiko # 指定本地的RSA私鑰文件 # 如果建立密鑰對時設(shè)置了密碼,password為passphrase。如果沒有passphrase則無需指定password參數(shù)。pkey = paramiko.RSAKey.from_private_key_file(’/home/you_username/.ssh/id_rsa’, password=’12345’) # 建立連接 ssh = paramiko.SSHClient() ssh.connect(hostname=’xx.xx.xx.xx’, port=22, username=’you_username’, pkey=pkey) # 執(zhí)行命令 stdin, stdout, stderr = ssh.exec_command(’ls -l’) # 結(jié)果放到stdout中,如果有錯誤將放到stderr中 print(stdout.read()) # 關(guān)閉連接 ssh.close()
方法4:基于公鑰的 Transport 方式登錄
該方法可以復(fù)用連接。
import paramiko # 指定本地的RSA私鑰文件 # 如果建立密鑰對時設(shè)置了密碼,password為passphrase。如果沒有passphrase則無需指定password參數(shù)。 pkey = paramiko.RSAKey.from_private_key_file(’/home/you_username/.ssh/id_rsa’, password=’12345’) # 建立連接 trans = paramiko.Transport((’xx.xx.xx.xx’, 22)) trans.connect(username=’you_username’, pkey=pkey) ssh = paramiko.SSHClient() ssh._transport = trans # 執(zhí)行命令,和傳統(tǒng)方法一樣 stdin, stdout, stderr = ssh.exec_command(’df -hl’) print(stdout.read().decode()) # 關(guān)閉連接 trans.close()
sftp 文件傳輸
import paramiko trans = paramiko.Transport((’xx.xx.xx.xx’, 22)) # 建立連接 trans.connect(username=’you_username’, password=’you_passwd’) # 實(shí)例化一個 sftp對象,指定連接的通道 sftp = paramiko.SFTPClient.from_transport(trans) # 發(fā)送文件 sftp.put(localpath=’/tmp/11.txt’, remotepath=’/tmp/22.txt’) # 下載文件 sftp.get(remotepath=’/tmp/22.txt’, localpath=’/tmp/33.txt’) trans.close()
參考
https://www.linuxprobe.com/log-in-to-remote-service-python.html
總結(jié)
到此這篇關(guān)于借助Paramiko通過Python實(shí)現(xiàn)linux遠(yuǎn)程登陸及sftp的操作的文章就介紹到這了,更多相關(guān)python paramiko實(shí)現(xiàn)遠(yuǎn)程登陸 sftp內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 使用Hangfire+.NET 6實(shí)現(xiàn)定時任務(wù)管理(推薦)2. Xml簡介_動力節(jié)點(diǎn)Java學(xué)院整理3. 如何在jsp界面中插入圖片4. jsp實(shí)現(xiàn)登錄驗(yàn)證的過濾器5. phpstudy apache開啟ssi使用詳解6. xml中的空格之完全解說7. JSP之表單提交get和post的區(qū)別詳解及實(shí)例8. jsp文件下載功能實(shí)現(xiàn)代碼9. 詳解瀏覽器的緩存機(jī)制10. vue3+ts+elementPLus實(shí)現(xiàn)v-preview指令
