色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

借助Paramiko通過Python實現linux遠程登陸及sftp的操作

瀏覽:3日期:2022-08-02 10:28:26

paramiko是一個用于做遠程控制的模塊,使用該模塊可以對遠程服務器進行命令或文件操作,paramiko是用python語言寫的一個模塊,遵循SSH2協議,支持以加密和認證的方式,進行遠程服務器的連接。

由于使用的是python這樣的能夠跨平臺運行的語言,所以所有python支持的平臺,如Linux, Solaris, BSD, MacOS X, Windows等,paramiko都可以支持,因此,如果需要使用SSH從一個平臺連接到另外一個平臺,進行一系列的操作時,paramiko是最佳工具之一。

本文重點給大家介紹借助Paramiko通過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 paramiko

方法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()

參考

https://www.linuxprobe.com/log-in-to-remote-service-python.html

總結

到此這篇關于借助Paramiko通過Python實現linux遠程登陸及sftp的操作的文章就介紹到這了,更多相關python paramiko實現遠程登陸 sftp內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 91免费观看视频 | 国产麻豆入在线观看 | 亚洲欧美日本国产 | 国产精品久久久久免费 | 精品国产品香蕉在线观看 | 精品老司机在线视频香蕉 | 91精品国产福利尤物免费 | 手机在线看福利 | 国产国产人免费视频成69堂 | 国内精品免费一区二区三区 | 国产精品免费视频一区二区三区 | 天天看夜夜操 | 久久久久久久久影院 | 精品国产一区在线观看 | 欧美亚洲综合网 | 三级黄色片网址 | 亚欧视频在线观看 | 日本免费一区二区三区毛片 | 99久久精品男女性高爱 | 免费小视频在线观看 | 日韩中文字幕精品久久 | 欧美三级免费 | 亚洲精品一区二区在线观看 | 色偷偷成人网免费视频男人的天堂 | 国产成人mv在线观看入口视频 | av免费网站在线观看 | 免费人成黄页网站在线观看国产 | 欧美三级 欧美一级 | 国产网红自拍 | 波多野结衣3女同在线观看 波多野结衣aⅴ在线 | 欧美日韩一级片在线观看 | 亚洲欧美中文日韩二区一区 | 爽爽日本在线视频免费 | 亚洲性色视频 | 手机看片日韩国产 | 色碰碰| 久久成人免费播放网站 | 免费国产a国产片高清不卡 免费国产不卡午夜福在线 免费国产不卡午夜福在线观看 | 欧美日韩国产在线观看一区二区三区 | 成年男女免费视频网站 | 欧美国产日韩在线 |