python - eventlet 中network connect 相关的函数
ringa_lee
ringa_lee 2017-04-18 09:28:06
[Python讨论组]

在eventlet 库中有eventlet.connect,有eventlet.listen 等相关的函数,实现网络相关的功能,但是在python 中也有与socket 相关的库函数,想问下eventlet.XXX等函数与直接的库函数中的函数有什么区别马?有哪些优化马?

ringa_lee
ringa_lee

ringa_lee

全部回复(1)
高洛峰

It uses epoll or kqueue or libevent for highly scalable non-blocking I/O

就是说eventlet是异步的。运用event loop和coroutine来完成并发。标准库内的函数(asyncio除外)是传统的同步I/O方式。

小小科普:

现如今做并发有两种方式:

  1. thread pool + 阻塞I/O

  2. event loop + 非阻塞I/O

1 容易理解。2 是一个单线程解决方案。所有网络I/O是非阻塞的。通过一个event loop来处理所有事件。伪代码如下

while True:
  wait_for_event()
  handle_event()
  

解决大量的并发2有很多优势。所以产生了很多解决方案。eventlet是其中之一。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号