epoll 为什么能提高网络性能

epoll⾼性能最根本的原因是,epoll 可以同时监听多个fd事件,这在很⼤程度地减少了⽆⽤的进程上下⽂切换,让进程更专注地处理⽹络请求。

其实在内核的硬、软中断上下⽂中,包从⽹卡接收过来进⾏处理,然后放到socket的接

收队列。再找到socket关联的epiter,并把它添加到epol对象的就绪链表中。

在⽤户进程中,通过调⽤epoll wait来 查看就绪链表中是否有事件到达,如果有,直

接取⾛进⾏处理。处理完毕再次调⽤epoll_ wait。 在⾼并发的实践中,只要活⼉⾜够多,

epoll walt根本不会让进程阻塞。⽤户进程会⼀直⼲活⼉,⼀直⼲活⼉,直到epoll watt⾥

实在没活⼉可⼲的时候才主动让出CPU。这就是epoll⾼效的核⼼原因所在!

相关推荐
迎風吹頭髮1 分钟前
Linux内核架构浅谈8-Linux内核与UNIX的传承:设计思想与特性差异
linux·运维·架构
猫头虎25 分钟前
如何查看局域网内IP冲突问题?如何查看局域网IP环绕问题?arp -a命令如何使用?
网络·python·网络协议·tcp/ip·开源·pandas·pip
黑马金牌编程31 分钟前
Linux 服务器常见的性能调优
linux·运维·服务器·性能优化
jieyu111932 分钟前
网络、主机安全扫描工具
linux·安全·系统安全
tianyuanwo34 分钟前
Linux进程管理中的T状态问题分析与解决体系
linux·运维·进程管理·t状态
liuyao_xianhui1 小时前
Linux_基本指令1
linux·运维·服务器
守望时空332 小时前
Linux挂载NTFS分区指南
linux
shan~~3 小时前
linux达梦数据库操作
linux·数据库·chrome
liliangcsdn3 小时前
LLM时代基于unstructured解析非结构化pdf
linux·服务器·数据分析
hello_2503 小时前
动手模拟docker网络-bridge模式
网络·docker·桥接模式