Web應(yīng)用程序在ssl.py中在self._sslobj.do_handshake()上掛了幾個小時。
瀏覽了StackOverflow的Python部分之后,我發(fā)現(xiàn)了一些可能無法解決導(dǎo)致該問題的核心問題的方法,但是絕對足以應(yīng)付出現(xiàn)該問題的任何情況。以下問題具有各種解決方案,如果函數(shù)花費(fèi)太長時間才能完成,則會拋出某種異常。這就是我最終解決此問題的方式。最佳答案是僅UNIX,但是還有其他一些使用線程并在每個平臺上都可以使用的工具:
超時功能(如果完成時間太長)
這是一個奇怪的問題,實(shí)際上很難復(fù)制。在成千上萬的API調(diào)用之后,我只見過兩次。我認(rèn)為,有人會找到比這更好的解決方案的可能性很小,這雖然有點(diǎn)可笑,但絕對可以解決問題。您可以引發(fā)異常,然后再次嘗試SSL連接,或者繼續(xù)執(zhí)行程序的另一部分。
我認(rèn)為目前的答案就足夠了,但是如果有人有更好的選擇,請隨時提出。老實(shí)說,似乎唯一解決此問題的方法可能是實(shí)際ssl.py庫中的錯誤修復(fù),但我無法肯定地說。
解決方法我正在使用Python2.7.5。我有一個網(wǎng)絡(luò)應(yīng)用程序,該應(yīng)用程序每隔幾分鐘會查詢API,并且在最后一天左右的時間內(nèi)一直成功運(yùn)行。但是,在將其放置幾個小時后,我回來了,發(fā)現(xiàn)我的程序停頓了好幾個小時都沒有任何活動。我退出了該程序,發(fā)現(xiàn)在一天中的大部分時間里,在一次API調(diào)用期間,該程序都已停在ssl握手方法中。
這是回溯:
...File '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/ssl.py',line 143,in __init__ self.do_handshake()File '/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/ssl.py',line 305,in do_handshake self._sslobj.do_handshake()
我做了一些研究,似乎這是Python 2.6中SSL庫的問題,但此后已修復(fù)。我想知道為什么我的程序在不拋出異常或任何異常的情況下卡在這里。
如果有一種方法可以設(shè)置SSL握手方法的超時時間,那么我很樂意這樣做,因?yàn)槲蚁M苊馕业某绦虮活愃频氖虑闊o限期地停止。我正在使用RequestsHTTP庫,如果有問題,它將在Mac OSX 10.9上運(yùn)行。有什么建議嗎?
編輯:我進(jìn)行了一些研究,盡管2.6中實(shí)現(xiàn)了“修復(fù)”,但似乎其他人也遇到了SSL的特定問題。但是,尚不確定解決方案是什么。任何幫助表示贊賞。
編輯3: 添加我的解決方案作為對此問題的答案。
相關(guān)文章:
1. mysql優(yōu)化 - mysql count(id)查詢速度如何優(yōu)化?2. mysql主從 - 請教下mysql 主動-被動模式的雙主配置 和 主從配置在應(yīng)用上有什么區(qū)別?3. python - django 里自定義的 login 方法,如何使用 login_required()4. node.js - node_moduls太多了5. 主從備份 - 跪求mysql 高可用主從方案6. angular.js - 不適用其他構(gòu)建工具,怎么搭建angular1項(xiàng)目7. python如何不改動文件的情況下修改文件的 修改日期8. java8中,邏輯與 & 符號用在接口類上代表什么意思9. python - 關(guān)于ACK標(biāo)志位的TCP端口掃描的疑惑?10. html - 請教一個前端css問題。
