java+spark: org.apache.spark.SparkException: Job abgebrochen: Aufgabe nicht serialisierbar: java.io.NotSerializableException

Ich bin neu zu entfachen, und versuchte, um das Beispiel auszuführen JavaSparkPi.java es läuft auch gut, aber da ich dies in einem anderen java-s kopiere ich alle Sachen vom main auf eine Methode in der Klasse und versuchen, rufen Sie die Methode in main, es saids

org.apache.spark.SparkException: Job abgebrochen: Aufgabe nicht serialisierbar:
java.io.NotSerializableException

der code sieht so aus:

public class JavaSparkPi {

public void cal(){
    JavaSparkContext jsc = new JavaSparkContext("local", "JavaLogQuery");
    int slices = 2;
    int n = 100000 * slices;

    List<Integer> l = new ArrayList<Integer>(n);
    for (int i = 0; i < n; i++) {
        l.add(i);
    }

    JavaRDD<Integer> dataSet = jsc.parallelize(l, slices);

    System.out.println("count is: "+ dataSet.count());
    dataSet.foreach(new VoidFunction<Integer>(){
        public void call(Integer i){
            System.out.println(i);
        }
    });

    int count = dataSet.map(new Function<Integer, Integer>() {
        @Override
        public Integer call(Integer integer) throws Exception {
            double x = Math.random() * 2 - 1;
            double y = Math.random() * 2 - 1;
            return (x * x + y * y < 1) ? 1 : 0;
        }
    }).reduce(new Function2<Integer, Integer, Integer>() {
        @Override
        public Integer call(Integer integer, Integer integer2) throws Exception {
            return integer + integer2;
        }
    });

    System.out.println("Pi is roughly " + 4.0 * count / n);
}

public static void main(String[] args) throws Exception {

    JavaSparkPi myClass = new JavaSparkPi();
    myClass.cal();
}
}

jemand ne Idee hierzu? danke!

InformationsquelleAutor user2810081 | 2014-06-04
Schreibe einen Kommentar