黑猴子的家:Spark Shell

spark-shell是Spark自带的交互式Shell程序,方便用户进行交互式编程,用户可以在该命令行下用scala编写spark程序

1、启动Spark shell
[victor@node1 spark]$ bin/spark-shell \
--master spark://node1:7077 \
--executor-memory 2G \
--total-executor-cores 2

尖叫提示:如果启动 spark shell 时没有指定 master 地址,但是也可以正常启动 spark shell 和执行 spark shell 中的程序,其实是启动了 spark 的 local 模式,该模式仅在本机启动一个进程,没有与集群建立联系

2、编写WordCount程序

(1)启动hdfs

[victor@node1 hadoop-2.8.2]$ sbin/start-dfs.sh

(2)上传文件

[victor@node1 hadoop-2.8.2]$ bin/hdfs dfs -put ../spark/RELEASE /

hdfs://node1:9000/RELEASE

(3)wordcount输出到HDFS上

scala> sc.textFile("hdfs://node1:9000/RELEASE").flatMap( \
_.split(" ")).map((_,1)).reduceByKey( \
_+_).saveAsTextFile("hdfs://node1:9000/out")

尖叫提示:Spark Shell 中已经默认将 SparkContext 类初始化为对象 sc。用户代码如果需要用到,则直接应用 sc 即可

(4)查看WordCount在HDFS上的输出

[victor@node1 hadoop]$ bin/hadoop fs -cat /out/p*

(5)WordCount控制台打印

scala> sc.textFile("hdfs://node1:9000/RELEASE").flatMap( \
_.split(" ")).map((_,1)).reduceByKey(_+_).collect

res5: Array[(String, Int)] = Array(
(-Psparkr,1), (Build,1), (built,1), 
(-Phive-thriftserver,1), (-Pmesos,1), (2.7.3,1),
 (-Phadoop-2.7,1), (2.2.0,1), (Spark,1), 
(-Pyarn,1), (-DzincPort=3036,1), (flags:,1), 
(for,1), (-Phive,1), (Hadoop,1))
3、解析

scSparkContext对象,该对象是提交spark程序的入口
textFile(hdfs://node1:9000/RELEASE)hdfs中读取数据
flatMap(_.split(" "))map在压平
map((_,1))将单词和1构成元组
reduceByKey(_+_)按照key进行reduce,并将value累加
saveAsTextFile("hdfs://node1:9000/out")将结果写入到hdfs

9193428-6ac85fe55008a859.jpg
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值