天天看点

Netty业务开发常见Bug解析不显式初始化initialBytesToStripChannelHandler顺序错误ChannelHandler 共享问题分配ByteBuf方式错误未考虑ByteBuf的释放write(msg)就一定能写数据?

不显式初始化initialBytesToStrip

  • LengthFieldBasedFrameDecoder#initialBytesToStrip
Netty业务开发常见Bug解析不显式初始化initialBytesToStripChannelHandler顺序错误ChannelHandler 共享问题分配ByteBuf方式错误未考虑ByteBuf的释放write(msg)就一定能写数据?

ChannelHandler顺序错误

  • 解码编码顺序一定要注意
Netty业务开发常见Bug解析不显式初始化initialBytesToStripChannelHandler顺序错误ChannelHandler 共享问题分配ByteBuf方式错误未考虑ByteBuf的释放write(msg)就一定能写数据?

ChannelHandler 共享问题

  • 不该共享的共享了,并发时就有数据问题

    这个很容易理解,犯错了也会很严重,必须避免。

  • 该共享的不共享,每个 pipeline 自己又单独添加了,就等于重复存了该 handler 浪费内存
Netty业务开发常见Bug解析不显式初始化initialBytesToStripChannelHandler顺序错误ChannelHandler 共享问题分配ByteBuf方式错误未考虑ByteBuf的释放write(msg)就一定能写数据?

分配ByteBuf方式错误

分配器直接用

ByteBufAllocator.DEFAULT

等,而不是采用

ChannelHandlerContext.alloc()

Netty业务开发常见Bug解析不显式初始化initialBytesToStripChannelHandler顺序错误ChannelHandler 共享问题分配ByteBuf方式错误未考虑ByteBuf的释放write(msg)就一定能写数据?

未考虑ByteBuf的释放

对于堆外内存或内存池,我们必须手动去释放它,因为 GC 不负责处理。如果忘记释放,就会完蛋。

所以一般继承

Netty业务开发常见Bug解析不显式初始化initialBytesToStripChannelHandler顺序错误ChannelHandler 共享问题分配ByteBuf方式错误未考虑ByteBuf的释放write(msg)就一定能写数据?

完成内存释放。

Netty业务开发常见Bug解析不显式初始化initialBytesToStripChannelHandler顺序错误ChannelHandler 共享问题分配ByteBuf方式错误未考虑ByteBuf的释放write(msg)就一定能写数据?

write(msg)就一定能写数据?

Netty业务开发常见Bug解析不显式初始化initialBytesToStripChannelHandler顺序错误ChannelHandler 共享问题分配ByteBuf方式错误未考虑ByteBuf的释放write(msg)就一定能写数据?
  • ChannelHandlerContext.channel().writeAndFlush(msg)
Netty业务开发常见Bug解析不显式初始化initialBytesToStripChannelHandler顺序错误ChannelHandler 共享问题分配ByteBuf方式错误未考虑ByteBuf的释放write(msg)就一定能写数据?