亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么通過Python實現linux遠程登陸及sftp

發布時間:2022-10-19 15:00:43 來源:億速云 閱讀:292 作者:iii 欄目:開發技術

這篇文章主要講解了“怎么通過Python實現linux遠程登陸及sftp”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“怎么通過Python實現linux遠程登陸及sftp”吧!

1. 使用shell命令
$ sshpass -p ${passwd} ssh -p ${port} -l ${user} -o StrictHostKeyChecking=no xx.xx.xx.xx "ls -l"

然后你會發現,你的輸出有很多你并不需要,但是又不去不掉的一些信息。
對于shell 命令,可以直接使用管道,或者將標準輸出重定向到文件的方法取得執行結果。

2. 使用 subprocess

通過Python可以想到使用 os.popen,os.system,commands,subprocess 等一些命令執行庫來間接獲取系統信息 。這些庫獲取的 output 不僅有標準輸出,還包含標準錯誤信息。所以每次都要對 output 進行數據清理,然后整理格式化,才能得到我們想要的數據。

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) 
# 數據清理

總之,間接使用ssh命令的幾個問題:

  • 需要額外安裝 sshpass(如果不免密的話)

  • 干擾信息太多,數據清理、格式化相當麻煩

  • 代碼實現不夠優雅,可讀性太差

  • ssh 連接不能復用,一次連接僅能執行一次命令

  • 代碼無法全平臺,僅能在 Linux 和 OSX 上使用

3. 使用Paramiko
  • 安裝

python3 -m pip install
  • 方法1:基于用戶名和密碼的 sshclient 方式登錄
    該方法無法復用ssh連接。

import paramiko 
 
ssh = paramiko.SSHClient() 
# 允許連接不在know_hosts文件中的主機 
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) 
 
# 建立連接 
ssh.connect("xx.xx.xx.xx", username="root", port=22, password="you_password") 
 
# 使用這個連接執行命令 
ssh_stdin, ssh_stdout, ssh_stderr = ssh.exec_command("ls -l") 
 
# 獲取輸出 
print(ssh_stdout.read()) 
 
# 關閉連接 
ssh.close()
  • 方法2:基于用戶名和密碼的 transport 方式登錄
    該方法可以復用連接。

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()) 
 
# 關閉連接 
trans.close()
  • 方法3:基于公鑰的 SSHClient 方式登錄
    該方法無法復用ssh連接。

import paramiko 
 
# 指定本地的RSA私鑰文件 
# 如果建立密鑰對時設置了密碼,password為passphrase。如果沒有passphrase則無需指定password參數。
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) 
 
# 執行命令 
stdin, stdout, stderr = ssh.exec_command('ls -l') 
 
# 結果放到stdout中,如果有錯誤將放到stderr中 
print(stdout.read()) 
 
# 關閉連接 
ssh.close()
  • 方法4:基于公鑰的 Transport 方式登錄
    該方法可以復用連接。

import paramiko 
 
# 指定本地的RSA私鑰文件 
# 如果建立密鑰對時設置了密碼,password為passphrase。如果沒有passphrase則無需指定password參數。 
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 
 
# 執行命令,和傳統方法一樣 
stdin, stdout, stderr = ssh.exec_command('df -hl') 
print(stdout.read().decode()) 
 
# 關閉連接 
trans.close()
  • sftp 文件傳輸

import paramiko 
 
trans = paramiko.Transport(('xx.xx.xx.xx', 22)) 
 
# 建立連接 
trans.connect(username='you_username', password='you_passwd') 
 
# 實例化一個 sftp對象,指定連接的通道 
sftp = paramiko.SFTPClient.from_transport(trans) 
 
# 發送文件 
sftp.put(localpath='/tmp/11.txt', remotepath='/tmp/22.txt') 
 
# 下載文件 
sftp.get(remotepath='/tmp/22.txt', localpath='/tmp/33.txt') 
trans.close()

感謝各位的閱讀,以上就是“怎么通過Python實現linux遠程登陸及sftp”的內容了,經過本文的學習后,相信大家對怎么通過Python實現linux遠程登陸及sftp這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

镇赉县| 唐海县| 尚义县| 乐安县| 新建县| 武夷山市| 墨玉县| 宜川县| 郯城县| 综艺| 玉林市| 赞皇县| 盱眙县| 阆中市| 客服| 济南市| 共和县| 南京市| 铅山县| 永城市| 梁山县| 新兴县| 邵东县| 泌阳县| 响水县| 巨鹿县| 泊头市| 广安市| 怀化市| 长春市| 长阳| 凯里市| 色达县| 上饶市| 泰州市| 措美县| 云浮市| 灵宝市| 东辽县| 高州市| 观塘区|