欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決paramiko執(zhí)行命令超時的問題

 更新時間:2020年04月16日 11:42:28   作者:腳本小娃子  
這篇文章主要介紹了解決paramiko執(zhí)行命令超時的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

問題:paramiko遠程執(zhí)行命令,需要等到命令返回信息,如果命令執(zhí)行時間比較長,返回信息就需要等很久

方案:

1、使用nohup + 待執(zhí)行命令 + & ,使用后臺執(zhí)行的方式,應(yīng)該可以快速返回

2、設(shè)置paramiko的執(zhí)行命令等待超時時間

stdin, stdout, stderr = self.client.exec_command(cmd,timeout=10,get_pty=True)

其實上面的兩種方案都不可行:方案1,需要優(yōu)化,下面這種直接調(diào)用的方式會導(dǎo)致test.sh啟動不起來

stdin, stdout, stderr = self.client.exec_command(‘sh ~/test.sh &',get_pty=True)

方案2,對于需要等待很久的命令,如果timeout小于程序的執(zhí)行時間,還是會失敗,命令執(zhí)行失敗

最終的解決方案來自參考1

把執(zhí)行很久的sh文件A放入另一個sh文件B中,然后paramiko執(zhí)行文件B。摘錄原文:

paramiko遠程執(zhí)行后臺腳本“阻塞”問題

我寫的遠程命令通道上線之后,發(fā)現(xiàn)在遠程腳本中后臺再執(zhí)行另一個腳本,通道會一直等待后臺腳本執(zhí)行完成才會返回,有時甚至?xí)┧馈?/p>

1、復(fù)現(xiàn)過程如下:

①、編寫測試腳本

腳本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傳到遠程服務(wù)器上,比如放到192.168.1.10:/tmp/下。

②、發(fā)起遠程執(zhí)行

在本地執(zhí)行 python test.py,會發(fā)現(xiàn)整個腳本不會立即打印run ok,而是等30s之后才打印包括test.sh的所有輸出信息。

2、解決辦法

將遠程腳本的標準輸出stdout重定向到錯誤輸出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é)果了。其實原因很簡單,因為bash /tmp/test.sh & 雖然是后臺執(zhí)行,但是依然會產(chǎn)生標準輸出,一旦產(chǎn)生標準輸出,paramiko就會認為命令還未執(zhí)行完成,且stdout的buffer大于stderr,因此產(chǎn)生等待問題。

這里只要將腳本執(zhí)行的標準輸出重定向到錯誤輸出(1>&2),然后paramiko就可以使用stderr快速讀取遠程打屏信息了。

基于上面paramiko的原理:有stdout輸出,就認為命令沒有執(zhí)行完成。得出下面的解決方案,對于需要執(zhí)行很久test.sh,我們首先把標準輸出都發(fā)給標準錯誤輸出(1>&2),然后后臺啟動(&)

stdin, stdout, stderr = self.client.exec_command(‘bash ~/test.sh 1>&2 &',get_pty=True)

項目實踐,還有下面的方案:去掉參數(shù)get_pty,這樣就不會回傳標準輸出信息和標準錯誤信息

self.client.exec_command(‘bash ~/test.sh')

以上這篇解決paramiko執(zhí)行命令超時的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用scipy.optimize的fsolve,root函數(shù)求解非線性方程問題

    使用scipy.optimize的fsolve,root函數(shù)求解非線性方程問題

    這篇文章主要介紹了使用scipy.optimize的fsolve,root函數(shù)求解非線性方程問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 深入討論Python函數(shù)的參數(shù)的默認值所引發(fā)的問題的原因

    深入討論Python函數(shù)的參數(shù)的默認值所引發(fā)的問題的原因

    這篇文章主要介紹了深入討論Python函數(shù)的參數(shù)的默認值所引發(fā)的問題的原因,利用了Python解釋器在內(nèi)存地址分配中的過程解釋了參數(shù)默認值帶來陷阱的原因,需要的朋友可以參考下
    2015-03-03
  • Python3搭建http服務(wù)器的實現(xiàn)代碼

    Python3搭建http服務(wù)器的實現(xiàn)代碼

    這篇文章主要介紹了Python3搭建http服務(wù)器的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • flask中使用藍圖將路由分開寫在不同文件實例解析

    flask中使用藍圖將路由分開寫在不同文件實例解析

    這篇文章主要介紹了flask中使用藍圖將路由分開寫在不同文件實例解析,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • Python button選取本地圖片并顯示的實例

    Python button選取本地圖片并顯示的實例

    今天小編就為大家分享一篇Python button選取本地圖片并顯示的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • Python快速生成定制化的Word(docx)文檔

    Python快速生成定制化的Word(docx)文檔

    這篇文章主要為大家介紹了如何使用Python快速生成定制化的Word文檔實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • Django cookie和session的應(yīng)用場景及如何使用

    Django cookie和session的應(yīng)用場景及如何使用

    今天我們來重點看下Django中session和cookie的用法吧。我們會介紹cookie和session的工作原理,還會分享實際應(yīng)用的案例。
    2021-04-04
  • Python OpenCV實現(xiàn)視頻分幀

    Python OpenCV實現(xiàn)視頻分幀

    這篇文章主要為大家詳細介紹了Python OpenCV實現(xiàn)視頻分幀,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • Python簡潔優(yōu)雅的推導(dǎo)式示例詳解

    Python簡潔優(yōu)雅的推導(dǎo)式示例詳解

    這篇文章主要給大家介紹了關(guān)于Python簡潔優(yōu)雅的推導(dǎo)式的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 關(guān)于Python 內(nèi)置庫 itertools

    關(guān)于Python 內(nèi)置庫 itertools

    今天得這篇文章就來給大家介紹一下Python的系統(tǒng)庫itertools的 相關(guān)資料,需要的小伙伴可以參考下面文章的具體內(nèi)容
    2021-09-09

最新評論