4.2 创建RDD

4.2 创建RDD

由于Spark一切都是基于RDD的,如何创建RDD就变得非常重要,除了可以直接从父RDD转换,还支持两种方式来创建RDD:

1)并行化一个程序中已经存在的集合(例如,数组);

2)引用一个外部文件存储系统(HDFS、HBase、Tachyon或是任何一个支持Hadoop输入格式的数据源)中的数据集。

4.2.1 集合(数组)创建RDD

通过并行集合(数组)创建RDD,主要是调用SparkContext的parallelize方法,在Driver(驱动程序)中一个已经存在的集合(数组)上创建,SparkContext对象代表到Spark集群的连接,可以用来创建RDD、广播变量和累加器。可以复制集合的对象创建一个支持并行操作的分布式数据集(ParallelCollectionRDD)。一旦该RDD创建完成,分布数据集可以支持并行操作,比如在该集合上调用Reduce将数组的元素相加。

parallelize方法的定义如下:

def parallelize[T](seq: Seq[T], numSlices: Int = defaultParallelism): RDD[T]

其中,第一个参数为对象集合,第二个参数为设定的分片数,默认值为2,返回指定对象类型的RDD。

下面以Scala语言进行操作,展示如何从一个数组创建一个并行集合,并进行数组元素相加操作。

            scala> val data = Array(1, 2, 3, 4, 5)

data: Array[Int] = Array(1, 2, 3, 4, 5)

scala> val distData = sc.parallelize(data)

distData: org.apache.spark.rdd.RDD[Int] = ParallelCollectionRDD[0]…

scala> distData.reduce((a, b) => a + b)

res2: Int = 15

并行集合创建的一个重要参数是slices的数目,它指定了将数据集切分为几个分区。在集群模式中,Spark将会在每份slice上运行一个Task。当然,也可以通过parallelize方法的第二个参数进行手动设置(如sc.parallelize(data, 10)),可以为集群中的每个CPU分配2~4个slices(也就是每个CPU分配2~4个Task)。

4.2.2 存储创建RDD

Spark可以从本地文件创建,也可以由Hadoop支持的文件系统(HDFS、KFS、Amazon S3、Hypertable、HBase等),以及Hadoop支持的输入格式创建分布式数据集。

Spark支持textFile、SequenceFiles及任何Hadoop支持的输入格式。

1. 从各种分布式文件系统创建

RDD可以通过SparkContext的textFile(文本文件)方法创建,其定义如下:

def textFile(path: String, minPartitions: Int = defaultMinPartitions): RDD[String]

其中,第一个参数指定文件的URI地址(本地文件路径,或者hdfs://、sdn://、kfs://……),并且以“行”的集合形式读取,第二个参数和parallelize方法一样也是用来指定分片数。下面以Scala语言进行操作为例,展示如何从一个数组创建一个并行集合。

          scala> val distFile = sc.textFile(“dfs://data.txt”)

distFile: org.apache.spark.rdd.RDD[String] =spark.HadoopRDD@1d4cee08

一旦创建了并行集合,distFile变量实质上转变成新的RDD,可以使用Map和Reduce操作将所有行数的长度相加:

distFile.map(s => s.length).reduce((a, b) => a + b).

注意

如果使用本地文件系统中的路径,那么该文件在工作节点必须可以被相同的路径访问。这可以通过将文件复制到所有的工作节点或使用网络挂载的共享文件系统实现。所有Spark基于的文件输入方法(包括textFile方法),都支持路径、压缩文件和通配符。可以使用textFile("/path")、textFile("/path/*.txt")和textFile("/path /*.gz")。

HDFS数据块大小为64的MB的倍数,Spark默认为每一个数据块创建一个分片。如果需要一个分片包含多个数据块,可以通过传入参数来指定更多的分片。

wholeTextFiles方法可以读取一个包含多个小的文本文件的目录,并通过键-值对(其中key为文件路径,value为文件内容)的方式返回每一个目录。而textFile函数为每个文件中的每一行返回一个记录。

2.从支持Hadoop输入格式数据源创建

对于其他类型的Hadoop输入格式,可以使用SparkContext.hadoopRDD方法来加载数据,也可以使用SparkContext.newHadoopRDD来处理这些基于新Mapreduce API的输入格式。RDD.saveAsObjectFile和SparkContext.objectFile支持以序列化的Java对象组成简单的格式来保存RDD,并提供了一个简单的方法来保存任何RDD。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容