我是靠谱客的博主 健壮超短裙,最近开发中收集的这篇文章主要介绍Netty报Direct buffer memory错误,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

最近基于Netty的NIO做应用底层通讯架构的实现(服务发现,分布式,高可用,软负载)。遇到java.lang.OutOfMemoryError: Direct buffer memory内存溢出错误,查了很多网上材料都不好使,这里总结一下我的解决方案。

原因:Netty启用了堆外内存DirectByteBuffer实现了零拷贝,堆外内存对young gc免疫,只有在full gc的时候才被收回。


网上解决方案一:启动添加-XX:MaxDirectMemorySize=256m参数,允许系统自动调用System.gc()(启动参数不得有-XX:+DisableExplicitGC)【没起作用】

网上解决方案二:主动发起full gc【没起作用】

分析:由于本系统数据量太大,网络传输不过来,造成数据堆积在堆外内存DirectMemory中,无法回收,数据越堆越多,造成OutOfMemoryError错误。


我的解决方案:在channel.writeAndFlush(msg);发送前做channel.isWritable()判断解决问题。测试发现毫无影响。

达到qps达75000笔/s(平均2.5kb),最大传输速度28MB/s

最后

以上就是健壮超短裙为你收集整理的Netty报Direct buffer memory错误的全部内容,希望文章能够帮你解决Netty报Direct buffer memory错误所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(45)

评论列表共有 0 条评论

立即
投稿
返回
顶部