关于thrift的使用

最近使用thrift,遇到的问题在这里说一下.使用的版本是0.10.0
1.thrift不稳定,在客户端发消息,会概率性的抛出异常,然后thrift服务就down掉了,只能一直监听着thrift服务,在它down掉时重启.
2.thirift有内存泄漏的问题,最开始没有调整jvm内存,出现oom,但是以为是内存设置的太低,便调整jvm参数.
过了几天发现服务器的内存一直增长.排查问题可能出现在thrift身上,网上关于这方面的问题也不是特别多,找到几篇文章参考下,做了些改动

异常:

[org.apache.thrift.server.TThreadedSelectorServer] - run() on SelectorThread exiting due to uncaught error
java.lang.OutOfMemoryError: Java heap space
    at java.nio.HeapByteBuffer.<init>(HeapByteBuffer.java:57)
    at java.nio.ByteBuffer.allocate(ByteBuffer.java:335)
    at org.apache.thrift.server.AbstractNonblockingServer$FrameBuffer.read(AbstractNonblockingServer.java:371)
    at org.apache.thrift.server.AbstractNonblockingServer$AbstractSelectThread.handleRead(AbstractNonblockingServer.java:203)
    at org.apache.thrift.server.TThreadedSelectorServer$SelectorThread.select(TThreadedSelectorServer.java:586)
    at org.apache.thrift.server.TThreadedSelectorServer$SelectorThread.run(TThreadedSelectorServer.java:541)

修改:

   TThreadedSelectorServer.Args tArgs = new TThreadedSelectorServer.Args(serverTransport);
        tArgs.processor(tprocessor);
        tArgs.maxReadBufferBytes = 1024 * 1024L;

设置了最大读取缓存.
过了一天内存没有大规模增长,后续效果还有待观察

文章:

https://issues.apache.org/jira/browse/THRIFT-2284
http://www.cnblogs.com/lishijia/p/5682326.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值