最近我们公司接了个单子,要支持远程观察。我们的产品一直都是在局域网中,应用的是WSAAsyncSelect模型。通过监听广播,得到邻居信息再连接邻居,这样一直运行的很好。但这回要在Internet上远程访问,必须将广播形势改成主动TCP连接。
开发到后期才发现性能问题:我们这个产品最多要同时连接100多个(互联),同时投递100个地址连接,会造成异步Socket消息堵塞,通过网络抓包工具发现SNY包堵塞没有及时发送出去,大概每次发送10个SNY包,间隔几秒再发送10个SNY包。修改Socket模型是不可能的,只能在原来基础上更改。
最后的解决方案是:每次保证8个地址投递连接,如有网络连接消息(连接上、没连接上、超时)就出发添加下一个地址连接,保证正在连接的地址不能超过8个。暂时效果还可以(没有Socket消息堵塞)。
下面还要通过实际检验效果,目前还担心的是这个模型是否能支持100多个连接。对于比较多连接的客户端WSAAsyncSelect模型还是显得有些力不从心。