iocp中GetQueuedCompletionStatus 121 信号灯超时时间已到 (error sem timeout)

Posted 风翼科技

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了iocp中GetQueuedCompletionStatus 121 信号灯超时时间已到 (error sem timeout)相关的知识,希望对你有一定的参考价值。

报错 :121 信号灯超时时间已到 (error sem timeout)

现象和 http://bbs.csdn.net/topics/370175898 描述一致

现象:GetQueuedCompletionStatus 返回后,GetLastError = 121 (信号灯超时时间已到),出现这个提示后,服务程序变卡,客户端不能流畅的接收数据;没有这个错误则客户端接收流畅。

代码如下

void App::AnalysisCommand(const boost::system::error_code& error,size_t bytes_recvd)
{
    if(!error && bytes_recvd > 0)
    {
    ........
boost::asio::async_read(socket_, boost::asio::buffer(m_buff, sizeof(MessageHeader)), boost::bind(&App::AnalysisCommand, this, boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred)); } else { LOG_ERROR<<"socket receive error message:"<< error.value()<<error.message();
} }

 

http://bbs.csdn.net/topics/370175898

https://blogs.msdn.microsoft.com/oldnewthing/20140717-00/?p=483/

http://microsoft.public.win32.programmer.networks.narkive.com/YVjj9q6G/calls-to-getqueuedcompletionstatus-returns-error-netname-deleted-or-error-sem-timeout#post1

http://blog.csdn.net/brook0344/article/details/60479590

根据csdn上那哥们说的,ERROR_SEM_TIMEOUT 每秒收到5000个以上的Accept时出现

 

以上是关于iocp中GetQueuedCompletionStatus 121 信号灯超时时间已到 (error sem timeout)的主要内容,如果未能解决你的问题,请参考以下文章

DELPHI中完成端口(IOCP)的简单分析

为啥 IOCP 在 BeginExecuteReader 中不起作用

Libevent源码分析--- IOCP

Libevent源码分析--- IOCP

我可以在 IOCP 中使用 accept() 吗?

如何确保 iocp 接收中的线程安全?