Netty使用遇见的几个小问题及解决

如何处理数据

不需要使用线程池启动线程处理数据了,因为Netty已经为处理数据创建了线程池!
直接在Handler的线程中处理数据就可以了

使用Netty,一定要要深入了解它的线程模型!之前我理解错误,试图使用线程池处理数据。结果建立多个连接时,产生了大量的线程池。
Netty使用遇见的几个小问题及解决_第1张图片

一定要释放Buffer的内存

Netty为了提高IO的性能,使用了直接内存,使用后需要手动释放,否则会导致内存泄露。
Netty使用遇见的几个小问题及解决_第2张图片

要注意TCP的粘包与分包问题

添加Decoder,做数据校验,过滤无效数据。

如何主动下发数据

使用Map保存Channel与客户端的关系,下发数据时,通过Channel实现下发;

如何判定设备离线

把客户端信息储存在Channel中,利用channelInactive 回调函数,实现设备离线处理。

参考
Netty(三) 什么是 TCP 拆、粘包?如何解决?
Netty报错did not read anything but decoded a message,原因解决

你可能感兴趣的:(Netty)