快速业务通道

Windows下完成端口移植Linux下的epoll

作者 佚名技术 来源 Linux系统 浏览 发布时间 2012-04-26
距离上一篇博客都已经半个多月了,这么多天一直在学习研究关于Windows的完成端口移植到Linuxepoll方面的内容.这两方面以前都没有太多的接触,花费了较长的时间.在连续加班两天后,用一个周末的代价换来了一个调试成功.下面就把最近的成果与各位网友分享一下.如有不正确之处,望指正. <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" /> 先来说说Windows下的完成端口.完成端口号称是Windows下面最复杂的异步IO操作.但是如果你想开发出具有高性能的、支持大量连接的网络服务程序的话,就将它拿下.这里假设你已经对完成端口有一定的了解了. 下面引用一下幽默讲解Windows支持的五种Socket I/O模型的例子来通俗的说一下完成端口究竟是怎么回事. 老陈有一个在外地工作的女儿,不能经常回来,老陈和她通过信件联系.他们的信会被邮递员投递到他们的微软信箱里. 我们平时使用的select模型,老陈每隔几分钟便到楼下看看是否有信.这样的方式会浪费老陈很多时间.同理,程序会阻塞在这里等待数据的到来,该进程(线程)无法进行其他的操作,导致性能的降低. WSAAsyncSelect模型、WSAEventSelect模型同为事件触发模型.此时,只要有信到,微软就会主动通知老陈.此时,老陈只需要等待通知即可,在等待过程中可以做其他的事情. Overlapped I/O 事件通知模型基本和上面两种类似.只是,老陈不需要上下楼取信了,他只需告诉微软自己在几楼几号,微软就会把信送到老陈家里. 后来微软推出了Overlapped I/O 完成例程模型,老陈将自己拆信阅读回复的过程告诉微软,微软就会按照上述步骤去处理信件. 但是,微软要处理的信件实在太多了,信箱经常崩溃.于是采用了新技术Completion Port来处理这些信件. 通过Win32的重叠I/O机制,应用程序可以提请一项I/O操作,重叠的操作请求在后台完成,而同一时间提请操作的线程去做其他的事情.等重叠操作完成后线程收到有关的通知.而一个完成端口其实就是一个通知队列,由操作系统把已经完成的重叠I/O请求的通知放入其中.当某项I/O操作一旦完成,某个可以对该操作结果进行处理的工作者线程就会收到一则通知. 完成端口的使用主要分两步. ,创建完成端口 HANDLE hIocp;
hIocp = CreateIoCompletionPort(
INVALID_HANDLE_VALUE,
NULL,
(ULONG_PTR)0,
0);
if (hIocp == NULL) {
// Error
} 完成端口创建后,要把将使用该完成端口的套接字与之关联起来.方法是再次调用CreateIoCompletionPort ()函数,第一个参数FileHandle设为套接字的句柄,第二个参数ExistingCompletionPort 设为刚刚创建的那个完成端口的句柄.
以下代码创建了一个套接字,并把它和前面创建的完成端口关联起来: SOCKET s;

s = socket(AF_INET, SOCK_STREAM, 0);

if (s == INVALID_SOCKET) {
// Error }
if (CreateIoCompletionPort((HANDLE)s,
hIocp,
(ULONG_PTR)0,
0) == NULL)
{
// Error
}
... 这时就完成了套接字与完成端口的关联操作.在这个套接字上进行的任何重叠操作都将通过完成端口发出完成通知.
其次,使用API函数GetQueuedCompletionStatus来不断的监听查询某个完成端口的I/O操作的结果.通常来讲,在主线程中都只创建一个完成端口,将所有的套接字都与此完成端口关联.而进行监听查询的线程数一般取CPU数量的两倍. BOOL GetQueuedCompletionStatus(
HANDLE CompletionPort, // handle to completion port
LPDWORD lpNumberOfBytes, // bytes transferred
PULONG_PTR lpCompletionKey, // file completion key
LPOVERLAPPED *lpOverlapped, // buffer
DWORD dwMilliseconds  // optional timeout value
);

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号