Web應(yīng)用程序在ssl.py中在self._sslobj.do_handshake()上掛了幾個(gè)小時(shí)。
瀏覽了StackOverflow的Python部分之后,我發(fā)現(xiàn)了一些可能無法解決導(dǎo)致該問題的核心問題的方法,但是絕對(duì)足以應(yīng)付出現(xiàn)該問題的任何情況。以下問題具有各種解決方案,如果函數(shù)花費(fèi)太長時(shí)間才能完成,則會(huì)拋出某種異常。這就是我最終解決此問題的方式。最佳答案是僅UNIX,但是還有其他一些使用線程并在每個(gè)平臺(tái)上都可以使用的工具:
超時(shí)功能(如果完成時(shí)間太長)
這是一個(gè)奇怪的問題,實(shí)際上很難復(fù)制。在成千上萬的API調(diào)用之后,我只見過兩次。我認(rèn)為,有人會(huì)找到比這更好的解決方案的可能性很小,這雖然有點(diǎn)可笑,但絕對(duì)可以解決問題。您可以引發(fā)異常,然后再次嘗試SSL連接,或者繼續(xù)執(zhí)行程序的另一部分。
我認(rèn)為目前的答案就足夠了,但是如果有人有更好的選擇,請(qǐng)隨時(shí)提出。老實(shí)說,似乎唯一解決此問題的方法可能是實(shí)際ssl.py庫中的錯(cuò)誤修復(fù),但我無法肯定地說。
解決方法我正在使用Python2.7.5。我有一個(gè)網(wǎng)絡(luò)應(yīng)用程序,該應(yīng)用程序每隔幾分鐘會(huì)查詢API,并且在最后一天左右的時(shí)間內(nèi)一直成功運(yùn)行。但是,在將其放置幾個(gè)小時(shí)后,我回來了,發(fā)現(xiàn)我的程序停頓了好幾個(gè)小時(shí)都沒有任何活動(dòng)。我退出了該程序,發(fā)現(xiàn)在一天中的大部分時(shí)間里,在一次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握手方法的超時(shí)時(shí)間,那么我很樂意這樣做,因?yàn)槲蚁M苊馕业某绦虮活愃频氖虑闊o限期地停止。我正在使用RequestsHTTP庫,如果有問題,它將在Mac OSX 10.9上運(yùn)行。有什么建議嗎?
編輯:我進(jìn)行了一些研究,盡管2.6中實(shí)現(xiàn)了“修復(fù)”,但似乎其他人也遇到了SSL的特定問題。但是,尚不確定解決方案是什么。任何幫助表示贊賞。
編輯3: 添加我的解決方案作為對(duì)此問題的答案。
相關(guān)文章:
1. 如何解決docker宿主機(jī)無法訪問容器中的服務(wù)?2. 前端 - CSS3 box-shadow如何設(shè)置,或者用什么方法可以產(chǎn)生圖中這樣陰影的效果。3. node.js - vue-cll+sass 樣式不出來 已經(jīng)npm install sass、 sass-loader了4. html - css 如何讓文字標(biāo)題顯示在邊框上?5. docker 下面創(chuàng)建的IMAGE 他們的 ID 一樣?這個(gè)是怎么回事????6. 在應(yīng)用配置文件 app.php 中找不到’route_check_cache’配置項(xiàng)7. html按鍵開關(guān)如何提交我想需要的值到數(shù)據(jù)庫8. vim中編輯HTML文件時(shí)換行不能縮進(jìn)9. HTML5中怎么判斷用戶是否正在瀏覽頁面?10. html - 微信端video標(biāo)簽播放mp4視頻,安卓端提示視頻解析錯(cuò)誤
