Epoll面对大量连接时的事件处理

KaleoVon 2014-01-04 05:05:00
最近写了一个epoll服务器,用的ET模式,关注了EPOLLRDHUP/EPOLLHUP/EPOLLERR,所有事件处理也都循环直到EAGAIN等。测试时,客户端循环发起4096个连接,服务器最终连接成功的只能有3000多个,且接受连接不连续,一顿一顿的。后来改成每256个连接sleep1毫秒后,基本可以达到4096了。然后直接关闭客户端窗口,服务器端收到的断开事件也只有3000多个。同样的情况用我写的iocp服务器,则连接断开都正常,且很平滑。请问大家这是什么情况?是否有什么疏漏?
...全文
189 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
qiluvon 2014-01-08
  • 打赏
  • 举报
回复 1
客户端向服务器发起连接,发送SYN,服务器回SYN+ACK,客户端收到后为ESTABLISHED状态,并向服务器发ACK。但ESTABLISHED不一定真的ESTABLISHED,会出现这种情况:client为ESTABLISHED状态而server为SYN_RECV状态。这是因为如果并发连接太多,服务器accept处理不过来,完成连接队列已满,收到客户端ACK后,无法正常建立连接。之后会向client发送多次的SYN+ACK,发送的次数定义在/proc/sys/net/ipv4/tcp_synack_retries中,默认为5。在发送5次之后还是无法建立连接,服务器就不会再重发,并将该半连接从半连接队列删除和释放。此时客户端依然是ESTABLISHED状态。如果此后客户端向服务器发送数据,服务器由于找不到对应连接而将数据包丢弃,客户端得不到ACK而会不断重发,服务器最终会向其发RST,导致client的这种半连接最后也会结束。
这是一门linux下c++通讯架构实战课程,针对c/c++语言已经掌握的很熟并希望进一步深造以将来用c++在linux下从事网络通讯领域/网络服务器的开发和架构工作。这门课程学习难度颇高但也有着极其优渥的薪水(最少30K月薪,最高可达60-80K月薪),这门课程,会先从nginx源码的分析和讲解开始,逐步开始书写属于自己的高性能服务器框架代码,完善个人代码库,这些,将会是您日后能取得高薪的重要筹码。本课程原计划带着大家逐行写代码,但因为代码实在过于复杂和精细,带着写代码可能会造成每节课至少要4~5小的超长间,所以老师会在课前先写好代码,主要的间花费在逐行讲解这些代码上,这一点望同学们周知。如果你觉得非要老师领着写代码才行的话,老师会觉得你当前可能学习本门课程会比较吃力,请不要购买本课程,以免听不懂课程并给老师差评,差评也会非常影响老师课程的销售并造成其他同学的误解。 这门课程要求您具备下面的技能:(1)对c/c++语言掌握的非常熟练,语言本身已经不是继续学习的障碍,并不要求您一定熟悉网络或者linux;(2)对网络通讯架构领域有兴趣、勇于挑战这个高难度的开发领域并期望用大量的付出换取高薪;在这门课程中,实现了一个完整的项目,其中包括通讯框架和业务逻辑框架,浓缩总结起来包括如下几点:(1)项目本身是一个极完整的多线程高并发的服务器程序;(2)按照包头包体格式正确的接收客户端发送过来的数据包, 完美解决收包的数据粘包问题;(3)根据收到的包的不同来执行不同的业务处理逻辑;(4)把业务处理产生的结果数据包正确返回给客户端;本项目用到的主要开发技术和特色包括:(1)epoll高并发通讯技术,用到的触发模式是epoll中的水平触发模式【LT】;(2)自己写了一套线程池来处理业务逻辑,调用适当的业务逻辑处理函数处理业务并返回给客户端处理结果;(3)线程之间的同步技术包括互斥量,信号量等等;(4)连接池中连接的延迟回收技术,这是整个项目中的精华技术,极大程度上消除诸多导致服务器程序工作不稳定的因素;(5)专门处理数据发送的一整套数据发送逻辑以及对应的发送线程;(6)其他次要技术,包括信号、日志打印、fork()子进程、守护进程等等;

18,356

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 网络编程
c++c语言开发语言 技术论坛(原bbs)
社区管理员
  • 网络编程
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧