美文网首页
Jstorm ACK 机制

Jstorm ACK 机制

作者: lmem | 来源:发表于2016-12-17 19:28 被阅读687次

https://github.com/alibaba/jstorm/wiki/Ack-%E6%9C%BA%E5%88%B6
Storm也支持ACK机制

(1)应用场景

通过Ack机制,spout发送出去的每一条消息,都可以确定是被成功处理或失败处理, 从而可以让开发者采取动作。比如在Meta中,成功被处理,即可更新偏移量,当失败时,重复发送数据。

因此,通过Ack机制,很容易做到保证所有数据均被处理,一条都不漏。

另外需要注意的,当spout触发fail动作时,不会自动重发失败的tuple,需要spout自己重新获取数据,手动重新再发送一次

ack机制即, spout发送的每一条消息,
==》在规定的时间内,spout收到Acker的ack响应,即认为该tuple 被后续bolt成功处理
==》在规定的时间内,没有收到Acker的ack响应tuple,就触发fail动作,即认为该tuple处理失败,
==》或者收到Acker发送的fail响应tuple,也认为失败,触发fail动作

另外Ack机制还常用于限流作用: 为了避免spout发送数据太快,而bolt处理太慢,常常设置pending数,当spout有等于或超过pending数的tuple没有收到ack或fail响应时,跳过执行nextTuple, 从而限制spout发送数据。
通过conf.put(Config.TOPOLOGY_MAX_SPOUT_PENDING, pending);
设置spout pend数。

(2)如何使用Ack机制

==》spout 在发送数据的时候带上msgid
==》设置acker数至少大于0;Config.setNumAckers(conf, ackerParal);
==》在bolt中完成处理tuple时,执行OutputCollector.ack(tuple), 当失败处理时,执行OutputCollector.fail(tuple); ** 推荐使用IBasicBolt, 因为IBasicBolt 自动封装了OutputCollector.ack(tuple), 处理失败时,请抛出FailedException,则自动执行OutputCollector.fail(tuple)**

(3)如何关闭Ack机制

有2种途径
==》spout发送数据是不带上msgid
==》设置acker数等于0

(4)原理

acker对于每个spout-tuple保存一个ack-val的校验值,它的初始值是0, 然后每发射一个tuple/ack一个tuple,那么tuple的id都要跟这个校验值异或一下, 并且把得到的值更新为ack-val的新值。那么假设每个发射出去的tuple都被ack了, 那么最后ack-val一定是0(因为一个数字跟自己异或得到的值是0)。

相关文章

  • Jstorm ACK 机制

    https://github.com/alibaba/jstorm/wiki/Ack-%E6%9C%BA%E5%8...

  • JStorm源码分析-7.Ack机制的实现

    1. Ack的使用 通过Ack机制,spout发送出去的每一条消息,都可以确定是被成功处理或失败处理。, 从而可以...

  • Kafka的ack机制

    简述kafka的ack机制 Kafka的ack机制,指的是producer的消息发送确认机制,这直接影响到Kafk...

  • IMI每日一概念IACK机制

    介绍 ACK(Acknowledgement)机制,即确认机制。在即时通讯开发领域,ACK机制是为了应对复杂多变的...

  • Ack机制

    1、ack是什么 ack 机制是storm整个技术体系中非常闪亮的一个创新点。 通过Ack机制,spout发送出去...

  • ack机制

    每个Consumer可能需要一段时间才能处理完收到的数据。如果在这个过程中,Consumer出错了,异常退出了,而...

  • 消息中间件如何保证消息可靠性

    Kafka producer端 ack机制 ack=0 发送端不感应broker是否接收成功 ack=1 消息发送...

  • JStorm:Window机制

    0x01、前言 1、Storm作为经典流计算框架,由于不支持Window,更别说Event Time了,虽说Tri...

  • RabbitMQ ack机制

    无ack模式(AcknowledgeMode.NONE) server端行为 rabbitmq server默认推...

  • JStorm

    JStorm JStorm官方网站 JStorm Chinese Documentation [github]

网友评论

      本文标题:Jstorm ACK 机制

      本文链接:https://www.haomeiwen.com/subject/kctamttx.html