对象文件是将对象序列化后保存的文件,采用Java的序列化机制。可以通过objectFile[k,v](path) 函数接收一个路径,读取对象文件,返回对应的 RDD,也可以通过调用saveAsObjectFile() 实现对对象文件的输出。因为是序列化所以要指定类型。
(1)创建一个RDD
scala> val rdd = sc.parallelize(Array(1,2,3,4))
rdd: org.apache.spark.rdd.RDD[Int] = ParallelCollectionRDD[19] at parallelize at
(2)将RDD保存为Object文件
scala> rdd.saveAsObjectFile(“file:///opt/module/spark/objectFile”)
(3)查看该文件

(4)读取Object文件
scala> val objFile = sc.objectFile[(Int)](“file:///opt/module/spark/objectFile”)
objFile: org.apache.spark.rdd.RDD[Int] = MapPartitionsRDD[31] at objectFile at
(5)打印读取后的Sequence文件
scala> objFile.collect
res19: Array[Int] = Array(1, 2, 3, 4)