IO基础-IO多路复用基础

本文探讨了Java中Selector使用不同实现(epollvspoll)对I/O多路复用的影响,分析了它们在数据结构、轮询效率、用户态/内核态切换以及epoll的高性能特性,特别提及了epoll如何通过红黑树和mmap技术优化性能并讨论了C10K问题和Reactor模式的应用。
摘要由CSDN通过智能技术生成

Java的Selector封装了底层epoll和poll的API,可以通过指定如下参数来调用执行的内核调用, 在Linux平台,如果指定

-Djava.nio.channels.spi.SelectorProvider=sun.nio.ch.PollSelectorProvider 则底层调用poll,

-Djava.nio.channels.spi.SelectorProvider=sun.nio.ch.EPollSelectorProvider 或者不指定,则底层调用epoll。

一、I/O多路复⽤比较

I/O多路复⽤与传统的多线程/多进程模型相⽐,I/O多路复⽤的最⼤优势是系统开销⼩,系统不需要创建新的额外进程或者线程,也不需要维护这些线程和进程的运⾏行,降低了系统的维护⼯作量,节省了系统的资源。

二、多路复用IO模型的实践方式对比(更准确的说Selector实现方式)

1、数据结构存储区别

        select 使⽤用fd_set(bitmap数组保存⽂文件描述符)默认1024

        poll 使⽤pollfd结构(链表保存⽂件描述符) fd打开数量最大是系统上限。

        epoll 使⽤用红黑树和双向链表保存⽂件描述符 fd打开数量最⼤是系统上限。

2、轮询的⽅方式

        select 遍历连接总数时间复杂度为O(n)

        poll 遍历连接总数时间复杂度为O(n)

        epoll最⼤的优点就在于它只管你“活跃”的连接,fd就绪后进行回调。时间复杂度为O(1)

3、⽤用户态和内核态切换

        select、poll 用户态和内核态切换,需要fd来回拷⻉。

        epoll 使⽤mmap加速内核与内存⽤户空间的消息传递

4、epoll的高性能原因:

        1、epoll使用了红黑树来保存需要监听的文件描述符事件,epoll_ctl增删改操作快速。

        2、epoll不需要遍历就能获取就绪fd,直接返回就绪链表即可。

        3、linux2.6 之后使用了mmap技术,数据不在需要从内核复制到用户空间,零拷贝。

        思考:是不是解决了C10K问题。解决了,还可以进行优化吗?

        可以使用 Reactor模式解决阻塞点。

参考:这次答应我,一举拿下 I/O 多路复用!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

技术分子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值