Linux网络编程【六】:TCP协议高性能服务器(http)模型之I/O多路转接epoll

本文介绍了Linux下的epoll机制,它是用于处理大量并发连接的高性能服务器模型,特别是针对网络编程中的TCP协议。epoll相较于poll和select具有更好的CPU利用率,并提供了水平触发和边缘触发两种模式。epoll的系统调用包括epoll_create、epoll_ctl和epoll_wait。文章详细解释了这些调用的功能,并阐述了epoll的优点,如无最大并发限制、效率提升和减少内存拷贝。最后,文中给出了服务器的具体实现代码。
摘要由CSDN通过智能技术生成

什么是epoll?

epoll是linux内核为处理大批量文件描述符而作了改进的poll,是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大

量并发连接中只有少量活跃的情况下的系统CPU利用率。另一点原因就是获取事件的时候,它无须遍历整个被侦听的描述符集,只要

遍历那些被内核IO事件异步唤醒而加入Ready队列的描述符集合就行了。

注:epoll除了提供select/poll那种IO事件的水平触发(Level Triggered)外,还提供了边缘触发(Edge Triggered),这就使得用户空

间程序有可能缓存IO状态,减少epoll_wait/epoll_pwait的调用,提高应用程序效率。

注:epoll文件描述符用完后,直接用close关闭即可,非常方便。事实上,任何被侦听的文件符只要其被关闭,那么它也会自动从被侦

听的文件描述符集合中删除,很是智能。

epoll相关的系统调用有:epoll_create, epoll_ctl和epoll_wait。

epoll_create:


返回值:>0:非空文件描述符;
-1:函数调用失败,同时会自动设置全局变量errno;
epoll_ctl:用来添加/修改/删除需要侦听的文件描述符及其事件.
epoll的事件注册函数,它不同于select()是在监听事件时告诉内核要监听什么类型的事件,而是在这里先注册要监听的事件类型。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值