Spark Accumulator示例代码

package examples;

import org.apache.spark.Accumulator;
import org.apache.spark.SparkConf;
import org.apache.spark.api.java.JavaRDD;
import org.apache.spark.api.java.JavaSparkContext;
import org.apache.spark.api.java.function.FlatMapFunction;

import java.util.Arrays;



public class AccumulatorExample {
    static final String FILE_PATH = "F:/tmp/spark/hello.txt";

    public static void main(String[] args) {
        SparkConf conf = new SparkConf()
                .setMaster("local[3]")
                .setAppName("AccumulatorExample");
        JavaSparkContext ctx = new JavaSparkContext(conf);

        //从驱动器程序读取文件
        JavaRDD<String> lines = ctx.textFile(FILE_PATH);
        //定义一个Accumulator对象, 初始值为0
        final Accumulator<Integer> blankLines = ctx.accumulator(0);

        JavaRDD rdd = lines.flatMap(
                new FlatMapFunction<String, String>() {
                    public Iterable<String> call(String line) throws Exception {
                        if(line.equals("")){
                            blankLines.add(1);
                        }
                        return Arrays.asList(line.split(" "));
                    }
                }
        );
        rdd.saveAsTextFile("out.txt");
        System.out.println(blankLines.value());
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值