完成端口IO模型
IOCP(IO完成端口)是一种伸缩性的IO模型,广泛应用于各种类型的高性能服务器,如Apache等。
IO完成端口,应用程序使用线程池处理异步IO请求的一种机制。
最初设计:
应用程序发出一些异步IO请求,设备驱动把这些工作项目排序到完成端口,在完成端口上等待线程池便可以处理这些完成IO。
完成端口实际上是一个WINDOWS IO结构,可以接收多种对象的句柄。
1 创建完成端口对象
调用CreateIoCompletionPort函数创建一个完成端口对象,winsock使用这个对象为任意数量的套接字句柄管理IO请求
HANDLE CreateIoCompletionPort( HANDLE FileHandle, //关联的套接字句柄 HANDLE ExistingCompletionPort,//创建完成端口的对象句柄 ULONG_PTR CompletionKey,//指定一个句柄唯一的数据 DWORD NumberOfConcurrentThreads//同时执行线程数量 );
此函数作用:1 创建完成端口对象 2 将一个或者多个句柄关联到IO完成端口对象
例子:
HANDLE hCompletion = ::CreateIoCompletionPort(INVALID_HANDLE_VALUE,0,0,0);
2 IO服务器线程和完成端口
关联套接字之前,创建一个或者多个工作线程,在完成端口上执行并处理投递到完成端口上的IO请求
3 完成端口和重叠IO
在套接字上投递重叠发送和接收请求处理IO。
IO操作完成后,系统向完成端口对象发送一个完成通知封包。
IO完成端口以 先进先出的方式排队
BOOL GetQueuedCompletionStatus( HANDLE CompletionPort, //完成端口对象句柄 LPDWORD lpNumberOfBytes,//取得IO操作期间 PULONG_PTR lpCompletionKey, LPOVERLAPPED* lpOverLapped, DWORD dwMilliseconds );
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?