Storm集群模式下cleanup解决方法

2 篇文章 0 订阅
1 篇文章 0 订阅
  1. 背景
    由于cleanup方法并不可靠,它只在local mode下生效,Storm集群模式下cleanup不会被调用执行。很多资源得不到释放

  2. 解决方案
    在kill topology之前,先deactivate相应的topology。在spout中实现deactivate()方法,deactivate()方法中给bolt emit特殊的数据(如:emit “shutDown”字符串给bolt),bolt中判断接收的数据为”shutDown”就调用cleanup()方法。在cleanup()方法中释放需要释放的资源。

  3. 流程图
    这里写图片描述

  4. 相关代码

    spout重写deactivate()方法代码如下:

    @Override
    public void deactivate(){
        LOGGER.info("deaactivate to spout and bolt");  
        try {
           //storm deactivate时发一条消息给bolt
           collector.emit(new Values("shutDown"));
        } catch (Exception e) {  
           e.printStackTrace();  
        }
    }
   bolt中execute()方法代码如下:
    @Override
    public void execute(Tuple input) {
        String message = input.getStringByField("loan_message");
        //判断是不是spout的deactivate传过来的消息
        if("shutDown".equals(message )) {
            cleanup();
        }
    }

注意事项: deactivate topology时,建议等待时间尽量长,时间过短消息来不及处理,会导致数据丢失

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

csgogogo_471

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值