1 回答

TA貢獻(xiàn)1712條經(jīng)驗(yàn) 獲得超3個(gè)贊
先說(shuō)純python的tornado,tornado應(yīng)該是最簡(jiǎn)單的基于epoll(或kqueue)的httpserver和httpclient,說(shuō)白了就是封裝了python標(biāo)準(zhǔn)庫(kù)的socket和select.epoll(或select.kqueue),所以你也可以照著tornado實(shí)現(xiàn)一個(gè)媲美nginx的httpserver。當(dāng)然,為了利用好這個(gè)基于epoll的的server,你需要在io處搞個(gè)回調(diào)函數(shù),只有當(dāng)你這個(gè)io結(jié)束,才執(zhí)行回調(diào)函數(shù),如果你這個(gè)io不結(jié)束,你就執(zhí)行了回調(diào)函數(shù)(同步的寫法),產(chǎn)生的后果當(dāng)然是阻塞(因?yàn)橐恢痹诘饶愕膇o結(jié)束),所以用了epoll,你就需要層層回調(diào),代碼肯定很難看的,tornado為了解決這個(gè)問(wèn)題,就加了個(gè)裝飾器以及利用了python的yield關(guān)鍵字,裝飾器的內(nèi)部實(shí)現(xiàn)的函數(shù)名字就叫replace_callback,顧名思義,就是替換回調(diào),yield會(huì)使函數(shù)或方法凍結(jié),相當(dāng)于你搞了個(gè)回調(diào),但看起來(lái)像同步的,當(dāng)然,這個(gè)寫法也有很不方便的地方,但已經(jīng)比回調(diào)爽多了。
tornado雖然是最簡(jiǎn)單的基于epoll的httpserver,但坑也非常明顯,前面說(shuō)了,tornado僅僅封裝了socket和select.epoll,這就導(dǎo)致,木有python數(shù)據(jù)庫(kù)適配器能和tornado無(wú)縫對(duì)接,只有兩種情況下滿足其一才能把數(shù)據(jù)庫(kù)適配器改造成tornado能用的,第一:這個(gè)適配器是純python的,關(guān)鍵是socket通信是純python的;第二:這個(gè)適配器自帶異步,例如psycopg2??墒蔷退銤M足了上面的情況,你還得用tornado自帶的ioloop和iostream進(jìn)行封裝,相當(dāng)麻煩。
gevent就不一樣了,作為另一個(gè)python協(xié)程庫(kù),里面封裝了C,這導(dǎo)致他不是純python的,無(wú)法適用pypy(除非提供cffi接口),gevent的特點(diǎn)是自己搞了個(gè)socket和select,通過(guò)monkey_patch的方法干掉了python自帶的socket和select,從最底層就開始玩epoll,用gevent做聊天室,不用像tornado那樣還需寫回調(diào)函數(shù)或yield,只需要調(diào)用gevent.event的wait和set方法。
gevent調(diào)用數(shù)據(jù)庫(kù)遠(yuǎn)比tornado簡(jiǎn)單,雖然它對(duì)適配器的要求和tornado一樣,但不需要你自己寫代碼封裝(或很少的代碼)
- 1 回答
- 0 關(guān)注
- 797 瀏覽
添加回答
舉報(bào)