解決paramiko執(zhí)行命令超時(shí)的問(wèn)題
問(wèn)題:paramiko遠(yuǎn)程執(zhí)行命令,需要等到命令返回信息,如果命令執(zhí)行時(shí)間比較長(zhǎng),返回信息就需要等很久
方案:
1、使用nohup + 待執(zhí)行命令 + & ,使用后臺(tái)執(zhí)行的方式,應(yīng)該可以快速返回
2、設(shè)置paramiko的執(zhí)行命令等待超時(shí)時(shí)間
stdin, stdout, stderr = self.client.exec_command(cmd,timeout=10,get_pty=True)
其實(shí)上面的兩種方案都不可行:方案1,需要優(yōu)化,下面這種直接調(diào)用的方式會(huì)導(dǎo)致test.sh啟動(dòng)不起來(lái)
stdin, stdout, stderr = self.client.exec_command(‘sh ~/test.sh &',get_pty=True)
方案2,對(duì)于需要等待很久的命令,如果timeout小于程序的執(zhí)行時(shí)間,還是會(huì)失敗,命令執(zhí)行失敗
最終的解決方案來(lái)自參考1
把執(zhí)行很久的sh文件A放入另一個(gè)sh文件B中,然后paramiko執(zhí)行文件B。摘錄原文:
paramiko遠(yuǎn)程執(zhí)行后臺(tái)腳本“阻塞”問(wèn)題
我寫(xiě)的遠(yuǎn)程命令通道上線之后,發(fā)現(xiàn)在遠(yuǎn)程腳本中后臺(tái)再執(zhí)行另一個(gè)腳本,通道會(huì)一直等待后臺(tái)腳本執(zhí)行完成才會(huì)返回,有時(shí)甚至?xí)┧馈?/p>
1、復(fù)現(xiàn)過(guò)程如下:
①、編寫(xiě)測(cè)試腳本
腳本1:test.sh
#!/bin/bash sleep 30 echo test end exit 0
腳本2:run.sh
#!/bin/bash bash /tmp/test.sh & echo run ok! exit 0
腳本3:test.py
import paramiko
client = paramiko.SSHClient()
client = paramiko.SSHClient()
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
client.connect(hostname='192.168.1.10', port=22, username='root', password='123456', timeout=300,allow_agent=False,look_for_keys=False)
stdin,stdout,stderr=client.exec_command("bash /tmp/run.sh")
result_info = ""
for line in stdout.readlines():
result_info += line
print result_info
將test.sh和run.sh傳到遠(yuǎn)程服務(wù)器上,比如放到192.168.1.10:/tmp/下。
②、發(fā)起遠(yuǎn)程執(zhí)行
在本地執(zhí)行 python test.py,會(huì)發(fā)現(xiàn)整個(gè)腳本不會(huì)立即打印run ok,而是等30s之后才打印包括test.sh的所有輸出信息。
2、解決辦法
將遠(yuǎn)程腳本的標(biāo)準(zhǔn)輸出stdout重定向到錯(cuò)誤輸出stderr即可,test.py 修改如下:
import paramiko
client = paramiko.SSHClient()
client = paramiko.SSHClient()
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
client.connect(hostname='192.168.1.10', port=22, username='root', password='123456', timeout=300,allow_agent=False,look_for_keys=False)
stdin,stdout,stderr=client.exec_command("bash /tmp/run.sh 1>&2")
result_info = ""
for line in stderr.readlines():
result_info += line
print result_info
現(xiàn)在執(zhí)行,就能立即得到結(jié)果了。其實(shí)原因很簡(jiǎn)單,因?yàn)閎ash /tmp/test.sh & 雖然是后臺(tái)執(zhí)行,但是依然會(huì)產(chǎn)生標(biāo)準(zhǔn)輸出,一旦產(chǎn)生標(biāo)準(zhǔn)輸出,paramiko就會(huì)認(rèn)為命令還未執(zhí)行完成,且stdout的buffer大于stderr,因此產(chǎn)生等待問(wèn)題。
這里只要將腳本執(zhí)行的標(biāo)準(zhǔn)輸出重定向到錯(cuò)誤輸出(1>&2),然后paramiko就可以使用stderr快速讀取遠(yuǎn)程打屏信息了。
基于上面paramiko的原理:有stdout輸出,就認(rèn)為命令沒(méi)有執(zhí)行完成。得出下面的解決方案,對(duì)于需要執(zhí)行很久test.sh,我們首先把標(biāo)準(zhǔn)輸出都發(fā)給標(biāo)準(zhǔn)錯(cuò)誤輸出(1>&2),然后后臺(tái)啟動(dòng)(&)
stdin, stdout, stderr = self.client.exec_command(‘bash ~/test.sh 1>&2 &',get_pty=True)
項(xiàng)目實(shí)踐,還有下面的方案:去掉參數(shù)get_pty,這樣就不會(huì)回傳標(biāo)準(zhǔn)輸出信息和標(biāo)準(zhǔn)錯(cuò)誤信息
self.client.exec_command(‘bash ~/test.sh')
以上這篇解決paramiko執(zhí)行命令超時(shí)的問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用scipy.optimize的fsolve,root函數(shù)求解非線性方程問(wèn)題
這篇文章主要介紹了使用scipy.optimize的fsolve,root函數(shù)求解非線性方程問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12
深入討論P(yáng)ython函數(shù)的參數(shù)的默認(rèn)值所引發(fā)的問(wèn)題的原因
這篇文章主要介紹了深入討論P(yáng)ython函數(shù)的參數(shù)的默認(rèn)值所引發(fā)的問(wèn)題的原因,利用了Python解釋器在內(nèi)存地址分配中的過(guò)程解釋了參數(shù)默認(rèn)值帶來(lái)陷阱的原因,需要的朋友可以參考下2015-03-03
Python3搭建http服務(wù)器的實(shí)現(xiàn)代碼
這篇文章主要介紹了Python3搭建http服務(wù)器的實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
flask中使用藍(lán)圖將路由分開(kāi)寫(xiě)在不同文件實(shí)例解析
這篇文章主要介紹了flask中使用藍(lán)圖將路由分開(kāi)寫(xiě)在不同文件實(shí)例解析,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01
Python button選取本地圖片并顯示的實(shí)例
今天小編就為大家分享一篇Python button選取本地圖片并顯示的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-06-06
Django cookie和session的應(yīng)用場(chǎng)景及如何使用
今天我們來(lái)重點(diǎn)看下Django中session和cookie的用法吧。我們會(huì)介紹cookie和session的工作原理,還會(huì)分享實(shí)際應(yīng)用的案例。2021-04-04
Python OpenCV實(shí)現(xiàn)視頻分幀
這篇文章主要為大家詳細(xì)介紹了Python OpenCV實(shí)現(xiàn)視頻分幀,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06
Python簡(jiǎn)潔優(yōu)雅的推導(dǎo)式示例詳解
這篇文章主要給大家介紹了關(guān)于Python簡(jiǎn)潔優(yōu)雅的推導(dǎo)式的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
關(guān)于Python 內(nèi)置庫(kù) itertools
今天得這篇文章就來(lái)給大家介紹一下Python的系統(tǒng)庫(kù)itertools的 相關(guān)資料,需要的小伙伴可以參考下面文章的具體內(nèi)容2021-09-09

