《Redis官方教程》- 事件库

    xiaoxiao2024-01-03  171

    为什么需要一个事件库(Event Library)?

    让我们通过一系列Q&A来弄明白。

    Q:你期望网络服务器都做些什么事情? A:在它监听的端口上等待连接的到来,然后接收(accpet)它们。

    Q:调用accept会产生一个描述符,我该怎么处理它? A:先保存这个描述符,然后对它进行非阻塞(non-blocking)的读写(read/write)操作。

    Q:为什么读写操作必须用非阻塞的方式呢? A:如果服务器阻塞在文件(在Unix世界socket也是文件)I/O操作上,这期间它还怎么处理其他连接的请求呢?

    Q:我想我必须在socket上做很多次非阻塞操作去看它什么时候准备好,是这样吗? A:是的,这就是事件库为你所做的工作,现在你明白了。

    Q:那事件库是怎么做到的呢? A:使用操作系统的轮询(polling)机制以及定时器(timer)。

    Q:有没有开源的事件库能完成你说的这些功能? A:当然有,libevent和libev就是这样的事件库。

    Q:Redis用开源事件库来处理Socket I/O吗? A:不,因为一些原因Redis使用自己的事件库。

    转载自 并发编程网 - ifeve.com 相关资源:敏捷开发V1.0.pptx
    最新回复(0)