eventlet高并發(fā)的網(wǎng)絡(luò)編程庫
eventlet是一款使用Python編寫的為高并發(fā)的網(wǎng)絡(luò)編程而設(shè)計(jì)的庫。由第二人生(secondlife)所開源發(fā)布。在開源云計(jì)算技術(shù)OpenStack里起到了比較重要的作用。
它通過greenlet提供的協(xié)程功能,讓開發(fā)者可以不用將以往的多線程等并發(fā)程序的開發(fā)方式轉(zhuǎn)變成異步狀態(tài)機(jī)模型,就能直接使用select/epoll/kqueue等操作系統(tǒng)提供的支持高并發(fā)IO接口,并且能盡可能地發(fā)揮它們?cè)诓l(fā)上的優(yōu)勢。
與它同類的另一款產(chǎn)品是Gevent,它們有著很類似的設(shè)計(jì)。
在CPython下,由于Gevent使用了Cython綁定了libev或者libevent等C庫,導(dǎo)致Gevent比eventlet有著更優(yōu)秀的性能。
但是也因?yàn)镃ython寫的部分組件,導(dǎo)致Gevent無法借助PyPy來給它加速,而eventlet則沒有這個(gè)限制。在PyPy的加速下,eventlet的性能可以有成倍的提升。
評(píng)論
圖片
表情
