Netty业务开发常见Bug解析
【摘要】 不显式初始化initialBytesToStrip
LengthFieldBasedFrameDecoder#initialBytesToStrip
ChannelHandler顺序错误
解码编码顺序一定要注意
ChannelHandler 共享问题
不该共享的共享了,并发时就有数据问题 这个很容易理解,犯错了也会很严重,必须避免。 该共享的不共享,每...
不显式初始化initialBytesToStrip
- LengthFieldBasedFrameDecoder#initialBytesToStrip
ChannelHandler顺序错误
- 解码编码顺序一定要注意
ChannelHandler 共享问题
-
不该共享的共享了,并发时就有数据问题
这个很容易理解,犯错了也会很严重,必须避免。 -
该共享的不共享,每个 pipeline 自己又单独添加了,就等于重复存了该 handler 浪费内存
分配ByteBuf方式错误
分配器直接用ByteBufAllocator.DEFAULT
等,而不是采用ChannelHandlerContext.alloc()
未考虑ByteBuf的释放
对于堆外内存或内存池,我们必须手动去释放它,因为 GC 不负责处理。如果忘记释放,就会完蛋。
所以一般继承
完成内存释放。
write(msg)就一定能写数据?
- ChannelHandlerContext.channel().writeAndFlush(msg)
文章来源: javaedge.blog.csdn.net,作者:JavaEdge.,版权归原作者所有,如需转载,请联系作者。
原文链接:javaedge.blog.csdn.net/article/details/111697385
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
作者其他文章
评论(0)