AcceptEx() bug in Windows 8 and all Server 2012 variants
Be aware that there is a known bug in Windows 8 and all Server 2012 variants which causes AcceptEx()
completions to be delayed in some situations. This was confirmed by a Microsoft representative on Microsoft Connect, see the error report ticket here. An example of how to demonstrate this bug, its likely affects and the current know causes can be found here in this Stack Overflow question.
I’m a little disappointed with the official response to this bug report. I wasn’t expecting a fix to be included in the imminent release of Server 2012 but it would be nice to get more information back from Microsoft about what the actual cause of the problem is. Right now the Stack Overflow question is the only source of information about what may cause this problem and which API calls it is caused by and affects. Given that it appears to be a bug in how IOCP completions are dispatched for threads that issued I/O requests but are now in some kind of blocking state (possibly something to do with APC dispatch and the fact the blocking thread is not currently in an alertable wait state - but this is all guess work).
Note that it is unlikely that code built with The Server Framework will suffer any problems from this bug. We always suggest that you never do blocking calls on I/O threads and all of our AcceptEx()
calls (except the first ones which are usually issued when the server starts up) are made from an I/O thread. As long as you are following our advice and are using a separate thread pool for potentially blocking operations then your code should run just fine even on operating systems where this bug is present.
I will be issuing a bug fix release shortly which will marshal the initial AcceptEx()
calls that are made when you call StartAcceptingConnections()
off of the calling thread and onto one of the I/O pool threads. This is an easy change which will require no changes to non library code and will remove any chance that these initial AcceptEx()
calls could suffer from delayed completion if you happen to call an inappropriate Windows API on that thread (currently just a synchronous ReadFile()
or anything that itself calls down to a synchronous ReadFile()
).
Note that this bug only affects AcceptEx()
completions and so only affects servers that use the CStreamSocketServerEx
class.