2 回答

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