由于工作要求,需要完成一个TCP服务器。果断采用了Netty作为TCP服务器,完成后觉得选Netty真实非常正确的选择。
问题发现
在开发的过程中遇到了TCP粘包的问题:由于TCP是一个连续的流,流先进入至缓冲区,然后再从缓冲区被取走,当一个包很大或者连续的数据包总长比缓冲区大的时候,应用无法知道一个数据包的长度是多少,就无法获取到正确的数据包。
解决办法
在数据包的前4位规定了数据包的长度。
幸运的是Netty提供了非常简便的解决方法。
解决拆包的问题
向数据包的前X位填充数据包的长度
Netty源码注释写的非常清晰,直白明了,这里就不做过多的阐述。
小问题
如果服务端发送了一条数据包给客户端,客户端需要响应(返回一条数据包给服务端),那服务端如何辨认接收到的响应对应是哪一个数据包呢?
HTTP请求又是如何做到一应一答的呢?