Python使用monkey.patch_all()解決協(xié)程阻塞問題
直接參考以下實(shí)例,采用協(xié)程訪問三個網(wǎng)站
由于IO操作非常耗時,程序經(jīng)常會處于等待狀態(tài)
比如請求多個網(wǎng)頁有時候需要等待,gevent可以自動切換協(xié)程
遇到阻塞自動切換協(xié)程,程序啟動時執(zhí)行monkey.patch_all()解決
# 由于IO操作非常耗時,程序經(jīng)常會處于等待狀態(tài)# 比如請求多個網(wǎng)頁有時候需要等待,gevent可以自動切換協(xié)程# 遇到阻塞自動切換協(xié)程,程序啟動時執(zhí)行monkey.patch_all()解決# 首行添加下面的語句即可from gevent import monkey; monkey.patch_all()import geventfrom urllib import requestdef run_task(url): print('Visit --> %s' % url) try: response = request.urlopen(url) data = response.read() print('%d bytes received from %s.' %(len(data), url)) except Exception: print('error')if __name__ == ’__main__’: urls = [’https://github.com/’, ’https://blog.csdn.net/’, ’https://bbs.csdn.net/’] # 定義協(xié)程方法 greenlets = [gevent.spawn(run_task, url) for url in urls] # 添加協(xié)程任務(wù),并且啟動運(yùn)行 gevent.joinall(greenlets)# 查看運(yùn)行結(jié)果可以發(fā)現(xiàn),三個協(xié)程是同時觸發(fā)的,但是結(jié)束順序不同# 網(wǎng)頁請求的時間不同,故結(jié)束順序不同# 但是該程序其實(shí)只有一個線程
輸出結(jié)果
Visit --> https://github.com/Visit --> https://blog.csdn.net/Visit --> https://bbs.csdn.net/bytes received from https://blog.csdn.net/.bytes received from https://bbs.csdn.net/.bytes received from https://github.com/.
Process finished with exit code 0
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 讓chatgpt將html中的圖片轉(zhuǎn)為base64方法示例2. ASP基礎(chǔ)知識Command對象講解3. 熊海CMS代碼審計(jì)漏洞分析4. asp中Request.ServerVariables的參數(shù)集合5. PHP session反序列化漏洞深入探究6. asp畫中畫廣告插入在每篇文章中的實(shí)現(xiàn)方法7. CSS Hack大全-教你如何區(qū)分出IE6-IE10、FireFox、Chrome、Opera8. PHP反序列化漏洞實(shí)例深入解析9. Thinkphp3.2.3反序列化漏洞實(shí)例分析10. ASP編碼必備的8條原則
