博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
完成端口IO模型
阅读量:6257 次
发布时间:2019-06-22

本文共 963 字,大约阅读时间需要 3 分钟。

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    );

转载地址:http://zsxsa.baihongyu.com/

你可能感兴趣的文章
SpringMVC源码分析系列
查看>>
SnakeWords开发--Android 2.2
查看>>
zookeeper的python客户端安装
查看>>
LINUX 下Open cv练习使用小记(2)
查看>>
JavaScript基础避免使用eval()(006)
查看>>
面向对象和面向过程的区别
查看>>
内置函数与匿名函数
查看>>
SSH实现登陆拦截器
查看>>
使用HttpWebRequest出错时获取详细的错误信息
查看>>
sql还原(.mdf文件还原)
查看>>
Mellanox infinoband RDMA SDP
查看>>
Nearest Common Ancestors(LCA)
查看>>
JS/atan2 pow
查看>>
Pythoh网络编程3:创建TCP服务器和客户端
查看>>
angularjs 出现 “Possibly unhandled rejection: cancel ”错误
查看>>
bzoj 2653 middle (主席树+二分)
查看>>
指导别人,弥补自己
查看>>
BZOJ3932: [CQOI2015]任务查询系统
查看>>
和make相关的一些命令
查看>>
Fiddler抓取https设置及其原理
查看>>