专栏首页IT杂记Thrift抛直接内存OOM一点解决思路

Thrift抛直接内存OOM一点解决思路

最近使用Thrift TThreadedSelectorServer服务方式,运行一段时间就会抛OutOfMemoryError: Direct buffer memory异常;

java.lang.OutOfMemoryError: Direct buffer memory
        at java.nio.Bits.reserveMemory(Bits.java:658) ~[na:1.7.0_67]
        at java.nio.DirectByteBuffer.<init>(DirectByteBuffer.java:123) ~[na:1.7.0_67]
        at java.nio.ByteBuffer.allocateDirect(ByteBuffer.java:306) ~[na:1.7.0_67]
        at sun.nio.ch.Util.getTemporaryDirectBuffer(Util.java:174) ~[na:1.7.0_67]
        at sun.nio.ch.IOUtil.read(IOUtil.java:195) ~[na:1.7.0_67]
        at sun.nio.ch.SocketChannelImpl.read(SocketChannelImpl.java:379) ~[na:1.7.0_67]
        at org.apache.thrift.transport.TNonblockingSocket.read(TNonblockingSocket.java:142) ~[libthrift-0.9.2.jar:0.9.2]
        at org.apache.thrift.server.AbstractNonblockingServer$FrameBuffer.internalRead(AbstractNonblockingServer.java:539) ~[libthrift-0.9.2.jar:0.9.2]
        at org.apache.thrift.server.AbstractNonblockingServer$FrameBuffer.read(AbstractNonblockingServer.java:388) ~[libthrift-0.9.2.jar:0.9.2]
        at org.apache.thrift.server.AbstractNonblockingServer$AbstractSelectThread.handleRead(AbstractNonblockingServer.java:203) ~[libthrift-0.9.2.jar:0.9.2]
        at org.apache.thrift.server.TThreadedSelectorServer$SelectorThread.select(TThreadedSelectorServer.java:590) ~[libthrift-0.9.2.jar:0.9.2]
        at org.apache.thrift.server.TThreadedSelectorServer$SelectorThread.run(TThreadedSelectorServer.java:545) ~[libthrift-0.9.2.jar:0.9.2]

很可能是直接内存没有做垃圾回收;

“垃圾收集进行时,虚拟机虽然会对Direct Memory进行回收,但是却不能像新生代和老年代一样,发现空间不足就通知收集器进行回收,它只能等到老年代满后做full gc,然后顺便帮它清理掉内存的废气对象”

如上引用自《深入理解java虚拟机》,程序可能一直在运行没有做过full gc,然后导致直接内存用光,另外直接内存默认值和堆大小一致

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • DateFormat 线程不安全

    一、测试 测试代码如下:  private static SimpleDateFormat sdf = new SimpleDateFormat("yy...

    囚兔
  • INET_ATON()函数在MySQL5.6版本和5.7版本的差异

    问题 ### The error occurred while setting parameters ### SQL: insert into t_gatewa...

    囚兔
  • 【翻译】GeoJSON格式规范-RFC7946

    本文翻译自https://tools.ietf.org/html/rfc7946 ,2018年1月27,28日两个大雪的周末,以序纪念。

    囚兔
  • Lua代码片段收集

    Lua实现闭包 --[[@Func :实现闭包 @Desc : 当一个函数内部嵌套另一个函数定义时,内部的函数体可以访问外部的函数的局部变量,这种特征...

    晚晴幽草轩轩主
  • LPC17XX之CAN

    1.CAN通信配置步骤: 1)电源使能:在PCONP寄存器中设置PCAN1/2 2)时钟使能:在PPCLK_SEL0寄存器中选择PCLK_CAN1/2和验收滤波...

    心跳包
  • 最新115道华为、京东、滴滴、美团精选Java面试题整理

    8. 反爬虫,如果是你如何进行反爬虫,如何绕过反爬措施。使用无头浏览器被检测到了,如何绕过

    程序员追风
  • 对性能调优标准一无所知?

    前几天,和一个同学瞎聊,他说,“我们公司的系统从来都没有经过性能调优,集成测试没问题后就上线了,上线后也几乎没出现过性能问题。”

    沉默王二
  • 前端基础-HTML发展历史

    cwl_java
  • VR社交市场迎来繁荣,随之而来的VR社交安全该如何解决?

    近段时间,行业内VR社交相关的消息相当火热。先是Redpill VR与Sensorium联合推出了一场VR社交音乐会;之后又是热门VR社交游戏《Rec Room...

    VRPinea
  • 阿里面试题

    10.java对象的序列化实现方式,以及为什么protobuffer为什么序列化性能较好

    Typhoon

扫码关注云+社区

领取腾讯云代金券