《关于gevent的几点思考》阅读笔记
生活随笔
收集整理的這篇文章主要介紹了
《关于gevent的几点思考》阅读笔记
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
[1]寫得很好,所以打算自己消化一下,增加一些自己的理解。(下面斜體表示原文引用)
1. greenlet/eventlet/gevent的關系
只要學gevent就行,其他扔掉
?
2. gevent猴子補丁
猴子補丁monkey_patch,將標準庫中大部分的阻塞式調用替換成非阻塞的方式,包括socket、ssl、threading、select、httplib等。通過monkey.patch_xxx()來打補丁。按照gevent文檔中的建議,應該將猴子補丁的代碼盡可能早的被調用,這樣可以避免一些奇怪的異常。
我是這樣理解的,gevent實現了協程的創建、切換和調度,本身是同步的,而猴子補丁將gevent調用的阻塞庫變成非阻塞的,兩者配合實現了高性能的協程。
3、4、6. 一張表格概括:
| 功能 | 是否加入gevent | 是否阻塞(IO異步) |
| time.sleep | 加入mokey.patch_all() | 阻塞 |
| time.sleep | 加入mokey.patch_all() | 非阻塞 |
| os.popen/os.system | 不加入mokey.patch_all() | 阻塞 |
| os.popen/os.system | 加入mokey.patch_all() | 非阻塞 |
| subprocess.call | 不加入mokey.patch_all() | 阻塞 |
| subprocess.call | 加入mokey.patch_all() | 非阻塞 |
| subprocess.Popen | 不加入mokey.patch_all() | 阻塞 |
| subprocess.Popen | 加入mokey.patch_all() | 非阻塞 |
| redis | 不加入mokey.patch_all() | 阻塞 |
| redis | 加入mokey.patch_all() | 非阻塞 |
| mysql | 加入與不加入mokey.patch_all() | 都是阻塞 |
| gevent文件IO | 加入與不加入mokey.patch_all() | 都是阻塞 |
monkey.patch_all將socket變成非阻塞
凡是阻塞的順序都是gevent.spawn來決定的
5. gevent和timeout
看到有文章說,gevent里使用timeout會失效,因為已經是非阻塞的了。
經過驗證,上面的說法是錯誤的。無論使用urllib2,requests庫,timeout設置都有效。
另外,gevent里有個Timeout對象,可以很方便的實現非阻塞式的超時控制
?
?
Reference:
[1]關于gevent的幾點思考
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的《关于gevent的几点思考》阅读笔记的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ubuntu云主机上Flask+uwsg
- 下一篇: gevent-tutorial翻译和解读