《关于gevent的几点思考》阅读笔记
[1]寫得很好,所以打算自己消化一下,增加一些自己的理解。(下面斜體表示原文引用)
1. greenlet/eventlet/gevent的關(guān)系
只要學(xué)gevent就行,其他扔掉
?
2. gevent猴子補(bǔ)丁
猴子補(bǔ)丁monkey_patch,將標(biāo)準(zhǔn)庫(kù)中大部分的阻塞式調(diào)用替換成非阻塞的方式,包括socket、ssl、threading、select、httplib等。通過(guò)monkey.patch_xxx()來(lái)打補(bǔ)丁。按照gevent文檔中的建議,應(yīng)該將猴子補(bǔ)丁的代碼盡可能早的被調(diào)用,這樣可以避免一些奇怪的異常。
我是這樣理解的,gevent實(shí)現(xiàn)了協(xié)程的創(chuàng)建、切換和調(diào)度,本身是同步的,而猴子補(bǔ)丁將gevent調(diào)用的阻塞庫(kù)變成非阻塞的,兩者配合實(shí)現(xiàn)了高性能的協(xié)程。
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來(lái)決定的
5. gevent和timeout
看到有文章說(shuō),gevent里使用timeout會(huì)失效,因?yàn)橐呀?jīng)是非阻塞的了。
經(jīng)過(guò)驗(yàn)證,上面的說(shuō)法是錯(cuò)誤的。無(wú)論使用urllib2,requests庫(kù),timeout設(shè)置都有效。
另外,gevent里有個(gè)Timeout對(duì)象,可以很方便的實(shí)現(xiàn)非阻塞式的超時(shí)控制
?
?
Reference:
[1]關(guān)于gevent的幾點(diǎn)思考
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的《关于gevent的几点思考》阅读笔记的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: ubuntu云主机上Flask+uwsg
- 下一篇: gevent-tutorial翻译和解读