91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

paramiko執行命令超時怎么辦

發布時間:2020-08-03 11:10:05 來源:億速云 閱讀:345 作者:小豬 欄目:開發技術

小編這次要給大家分享的是paramiko執行命令超時怎么辦,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

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

方案:

1、使用nohup + 待執行命令 + & ,使用后臺執行的方式,應該可以快速返回

2、設置paramiko的執行命令等待超時時間

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

其實上面的兩種方案都不可行:方案1,需要優化,下面這種直接調用的方式會導致test.sh啟動不起來

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

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

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

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

paramiko遠程執行后臺腳本“阻塞”問題

我寫的遠程命令通道上線之后,發現在遠程腳本中后臺再執行另一個腳本,通道會一直等待后臺腳本執行完成才會返回,有時甚至會僵死。

1、復現過程如下:

①、編寫測試腳本

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

②、發起遠程執行

在本地執行 python test.py,會發現整個腳本不會立即打印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

現在執行,就能立即得到結果了。其實原因很簡單,因為bash /tmp/test.sh & 雖然是后臺執行,但是依然會產生標準輸出,一旦產生標準輸出,paramiko就會認為命令還未執行完成,且stdout的buffer大于stderr,因此產生等待問題。

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

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

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

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

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

看完這篇關于paramiko執行命令超時怎么辦的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。

向AI問一下細節

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

AI

乐平市| 兰溪市| 大石桥市| 土默特左旗| 尚志市| 博罗县| 南丹县| 庆云县| 特克斯县| 周至县| 犍为县| 平顶山市| 博爱县| 昌平区| 安丘市| 绥中县| 海阳市| 巴中市| 密云县| 杭州市| 洪湖市| 福泉市| 灵丘县| 永济市| 莱阳市| 武陟县| 五莲县| 乳山市| 梨树县| 嘉定区| 扎鲁特旗| 海盐县| 乌鲁木齐市| 西藏| 体育| 广丰县| 丰镇市| 武鸣县| 梅河口市| 萨嘎县| 神池县|