libuv与uWebSocket 掉坑之旅

libuv和uWebSocket都是开源的,这一点很棒。

libuv是Node.js的内核,强大、简洁、优雅。

uWebSocket浅浅的封装了libuv,改装成websocket版(仅仅用了少量的libuv的东西)。

掉坑之旅开始:上周一切完美的事情,周一发生了转折。客户端和服务端在同一台机器上,客户端连接服务端,竟然需要1分钟左右才能连接上,拔掉网线,瞬间就连上了。这也太神奇了吧。一大堆业务逻辑,还是多线程,找起来真费劲,头皮发麻。小伙伴说是不是中毒了,一扫真的有毒。杀毒3小时后,还是一样的效果。痛定思痛,认真划分模块,一点点测试,终于找到了,原来服务端还需要连接一个远端的服务器,而这个服务器端口改了。

查看源码发现:uWebSocket 没有直接用Libuv封装的完成端口,自己又整了一套,其中:

::connect(fd, result->ai_addr, result->ai_addrlen);

这一句阻塞5秒左右。完成端口也没用多线程,这一句:

success = GetQueuedCompletionStatusEx

又阻塞5秒,再加上断线重连,其他的客户端根本没机会连上来。

 

找到问题,修改就容易了。

你可能感兴趣的:(笔记)