Flink DataSet API 之 Accumulators & Counters(累加器)

基本介绍

1、Accumulator即累加器,与Mapreduce counter的应用场景差不多,都能很好地观察task在运行期间的数据变化。可以在Flink job任务中的算子函数中操作累加器,但是只能在任务执行结束之后才能获得累加器的最终结果。

2、Counter是一个具体的累加器(Accumulator)实现。例如:IntCounter, LongCounter 和 DoubleCounter

用法

1:创建累加器:      private IntCounter numLines = new IntCounter();

2:注册累加器:      getRuntimeContext().addAccumulator("num-lines", this.numLines);

3:使用累加器:             this.numLines.add(1);

4:获取累加器的结果:  myJobExecutionResult.getAccumulatorResult("num-lines")

使用Demo

import org.apache.flink.api.common.accumulators.IntCounter
import org.apache.flink.api.common.functions.RichMapFunction
import org.apache.flink.api.scala.ExecutionEnvironment
import org.apache.flink.configuration.Configuration

object BatchDemoCounter {
  def main(args: Array[String]): Unit = {
    val env = ExecutionEnvironment.getExecutionEnvironment

    import org.apache.flink.api.scala._

    val data = env.fromElements("a","b","c","d")

    val res = data.map(new RichMapFunction[String, String] {
      val numLines = new IntCounter()//定义
      override def open(parameters: Configuration): Unit = {
        super.open(parameters)
        getRuntimeContext.addAccumulator("num-lines", numLines)// 注册
      }

      override def map(in: String): String = {
        this.numLines.add(1)// 使用
        in
      }
    }).setParallelism(4)
    res.writeAsText("d:/sshdata/count").setParallelism(1)
    val jobResult = env.execute("BatchDemoCounter")
    val num = jobResult.getAccumulatorResult[Int]("num-lines")// 获取
    println(num)
  }
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用中提到的DataSet是指Flink中的数据集,它是Flink中的一种数据结构,用于表示并处理大规模的数据集。FlinkDataSet API提供了一套丰富的操作符,可以对数据集进行转换、过滤、聚合等各种操作。 引用中的newRanks是指在迭代计算中,根据输入的邻接表和当前的排名值进行计算得到的新的排名值的数据集。在图计算中,通常会使用迭代算法来计算各个节点的排名值,每次迭代都会根据当前的排名值和邻接表进行计算,得到新的排名值。 引用中的result是指通过在两个数据集上进行连接操作后得到的结果数据集。在Flink中,可以使用join操作符将两个数据集按照指定的键进行连接,生成一个包含两个数据集中共有键的结果数据集。 因此,FlinkDataSet是用于表示和处理大规模数据集的数据结构,可以通过各种操作符对数据集进行转换和处理。在图计算中,可以使用DataSet进行迭代计算,并使用join操作符进行数据集之间的连接操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [flink dataset join笔记](https://blog.csdn.net/weixin_30391889/article/details/114753509)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值