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

被折叠的 条评论
为什么被折叠?



