Spark updateStateByKey Java 和 Scala 版本

Jvav版本

JavaPairDStream<String,Long> aggregateDStream = mapDSRDD.updateStateByKey(new Function2<List<Long>, Optional<Long>, Optional<Long>>() {
            /**
             *
             * @param v1 相同key传进来的值的集合
             * @param v2 集群中保存的那份值。
             * @return
             * @throws Exception
             */
            @Override
            public Optional<Long> call(List<Long> v1, Optional<Long> v2) throws Exception {
                long clickCount = 0L;
                if(v2.isPresent())
                {
                    clickCount = v2.get();
                }
                for(Long val:v1)
                {
                    clickCount+=val;
                }
                return Optional.of(clickCount);
            }
        });

Scala 实现

  val dailyProvinceCityClickCount = mapDStream.updateStateByKey[Long]((values:Seq[Long],state:Option[Long])=>{

      var tmpValue = 0L
      if(state.isDefined)
        {
          tmpValue = state.get
        }
      var index:Int = 0
      while(index<values.size)
        {
          tmpValue += values(index)
          index += 1
        }

      Option(tmpValue)
    })
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值