zoukankan      html  css  js  c++  java
  • 完成端口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
        );
  • 相关阅读:
    LockSupport的用法及原理
    ReentrantReadWriteLock读写锁详解
    Java的CountDownLatch和CyclicBarrier的理解和区别
    AbstractQueuedSynchronizer超详细原理解析
    走进JVM
    【题解】Hanoi塔问题
    【题解】二的幂次方
    【题解】桐桐的递归函数
    【题解】数的计数
    【题解】极品飞车
  • 原文地址:https://www.cnblogs.com/xing901022/p/2728296.html
Copyright © 2011-2022 走看看