溫馨提示×

溫馨提示×

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

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

如何借助Paramiko通過Python實(shí)現(xiàn)linux遠(yuǎn)程登陸

發(fā)布時(shí)間:2021-03-23 10:13:24 來源:億速云 閱讀:194 作者:小新 欄目:開發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)如何借助Paramiko通過Python實(shí)現(xiàn)linux遠(yuǎn)程登陸的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

paramiko是一個(gè)用于做遠(yuǎn)程控制的模塊,使用該模塊可以對遠(yuǎn)程服務(wù)器進(jìn)行命令或文件操作,paramiko是用python語言寫的一個(gè)模塊,遵循SSH2協(xié)議,支持以加密和認(rèn)證的方式,進(jìn)行遠(yuǎn)程服務(wù)器的連接。

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

1. 使用shell命令

$ sshpass -p ${passwd} ssh -p ${port} -l ${user} -o StrictHostKeyChecking=no xx.xx.xx.xx "ls -l"

然后你會(huì)發(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)錯(cuò)誤信息。所以每次都要對 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命令的幾個(gè)問題:

需要額外安裝 sshpass(如果不免密的話)
干擾信息太多,數(shù)據(jù)清理、格式化相當(dāng)麻煩
代碼實(shí)現(xiàn)不夠優(yōu)雅,可讀性太差
ssh 連接不能復(fù)用,一次連接僅能執(zhí)行一次命令
代碼無法全平臺(tái),僅能在 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") 
# 使用這個(gè)連接執(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í)設(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中,如果有錯(cuò)誤將放到stderr中 
print(stdout.read()) 
# 關(guān)閉連接 
ssh.close()

方法4:基于公鑰的 Transport 方式登錄

該方法可以復(fù)用連接。

import paramiko 
# 指定本地的RSA私鑰文件 
# 如果建立密鑰對時(shí)設(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í)例化一個(gè) 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()

感謝各位的閱讀!關(guān)于“如何借助Paramiko通過Python實(shí)現(xiàn)linux遠(yuǎn)程登陸”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI