How to solve SPARK-5063 in nested map functions

前端 未结 3 673
自闭症患者
自闭症患者 2021-01-12 12:10

RDD transformations and actions can only be invoked by the driver, not inside of other transformations; for example, rdd1.map(x => rdd2.values.count() * x) is

相关标签:
3条回答
  • 2021-01-12 12:56

    @maasg Firstly i used JavaPairRDD< TextFile, JavaRDD < Word > >, and it didn't work as you and @David Griffin said, it's not possible yet. Models:

    TextFile(String path, String text)

    Word(String word, Integer count)

    Now using JavaRDD < TextFile > and models have changed as:

    TextFile(String path, String text, List< Word > wordList)

    Word(String word, Integer count)

    Finally,

    List<Word> countDrafts = wordCount.map(v11 -> new Word(v11._1(), (long) 0)).collect();
    JavaRDD<TextFile> ft = fileTexts.map(v11 -> new TextFile(v11._1(), v11._2(), countDrafts));
    ft.foreach(textFile -> textFile.getWordList().forEach(word -> new  Word(word.getText(), getWordCountFromText(textFile.getText(), word.getText())))); 
    

    getWordCountFromText() function counts word in text of TextFile object, but not using spark reduce method unfortunately, using classic way.

    By the way, i will try DataFrames in next days, but i have short time to do this.

    Thank you all.

    0 讨论(0)
  • 2021-01-12 13:00

    In the same way nested operations on RDDs are not supported, nested RDD types are not possible in Spark. RDDs are only defined at the driver where, in combination with their SparkContext they can schedule operations on the data they represent.

    So, the root cause we need to address in this case is the datatype:

    JavaPairRDD<TextFile, JavaRDD<Word>> filesWithWords
    

    Which in Spark will have no possible valid use. Depending on the usecase, which is not further explained in the question, this type should become one of:

    A collection of RDDs, with the text file they refer to:

    Map<TextFile,RDD<Word>>
    

    Or a collection of (textFile,Word) by text file:

    JavaPairRDD<TextFile, Word>
    

    Or a collection of words with their corresponding TextFile:

    JavaPairRDD<TextFile, List<Word>>
    

    Once the type is corrected, the issues with the nested RDD operations will be naturally solved.

    0 讨论(0)
  • 2021-01-12 13:00

    When I got to this exact same point in my learning curve for Spark (tried and failed to use nested RDDs) I switched to DataFrames and was able to accomplish the same thing using joins instead. Also, in general, DataFrames appear to be almost twice as fast as RDDs -- at least for the work I have been doing.

    0 讨论(0)
提交回复
热议问题