IO模型

IO模型

Redis是单线程的,为什么支持高并发?node.js,nginx也是单线程的。
除了Redis数据是存在内存里面的,所有操作都是内存级别的,还有其它原因导致它有如此高的性能?

多路复用(事件轮训)

多路复用是一种IO模型,那系统中还有哪些IO模式?一起来看看吧

常见的IO模型

同步阻塞IO(Blocking IO)

传统IO模型,请求server,如果server没有返回,client会一直等待,直到超时

同步非阻塞IO(Non-blocking IO)

请求server,无论是否成功,server都会立刻返回结果

IO多路复用(IO Multiplexing)

即Reactor设计模式,select/epoll的好处就在于单个process就可以同时处理多个网络连接的IO。它的基本原理就是select/epoll这个function会不断的轮询所负责的所有socket,当某个socket有数据到达了,就通知用户进程。
现在操作系统多路复用API已经不再使用select系统调用,而改用epoll(Linux)和kqueue(FressBSD和MacOS)

异步IO(Asynchronous IO)

即Proactor设计模式,client发起read操作,就可以进行其它操作,server操作成功会通知client

参考:https://www.cnblogs.com/findu…

    原文作者:小小的太阳
    原文地址: https://segmentfault.com/a/1190000019325993
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞