Storm排错调优之Spout拉取造成内存溢出(OOM)

                                                               Storm排错调优之Spout拉取造成内存溢出

        原因分析:

         Storm框架的两个组件spout和bolt,由于Spout从Kafka拉取消息,bolt用于处理。一般情况下,处理速度低于拉取速度,导致bolt处理消耗资源过多。最终造成内存溢出。

       解决方案:

1.合理设置maxSpoutPengding的值。

当前设置为100  也就是p为100,nunm-tasks为1。

所以RotatingMap的最大个数限制为100。

由于之前未设置MaxSpoutPengding,spout产生新的tuple就会立即向后端传递,topo过载严重导致OOM。

         设置为100 ,此时storm会暂停发送tuple,直到发出去的tuple小于这个数字,起到对spout限速的作用。

2.合理设置message.timeout.secs

        这个配置设定了一个Tuple数需要应答的最大时间秒数限制,也就是超过这个时间就已经被认为失败,可能导致stormUI页面spout failed 。这个值设置的太小可能会导致tuple反复重新发送。

         默认值为30s

代码设置参数:

        Config config = topoConfig.buildStormTopoConfig();
        config.setMaxSpoutPending(100);
        config.setMessageTimeoutSecs(60);

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值