scala IDE for Eclipse开发Spark程序
1、开发环境准备
scala IDE for Eclipse:版本(4.6.1)
官网下载:http://scala-ide.org/download/sdk.html
百度云盘下载:链接:http://pan.baidu.com/s/1c2NAZdA 密码:au8t
scala-2.11.8.msi :
官网下载:http://www.scala-lang.org/download/2.11.8.html
百度云盘下载:链接:http://pan.baidu.com/s/1dEFlmcL 密码:u2fr
2、scala环境变量配置
配置path,配置SCALA_HOME/bin目录,如图:
在命令行窗口输入scala,如图:
安装成功!
3、安装scala IDE for Eclipse
直接默认安装即可。
4、新建一个scala project
新建一个TestSpark工程,如图:
这里的scala版本默认使用的是2.12.2,我们要scala的版本设置为2.11.8,
5、导入spark的所有jar包
spark-2.1.1-bin-hadoop2.7\jars :此处我使用spark版本是spark-2.1.1-bin-hadoop2.7。
spark版本跟你装在linux上的spark环境是一致的。
如图:
6、WordCount简单示例
6.1在TestSpark工程下新建一个words.txt文件
words.txt内容如下:
- HelloHadoop
- HelloBigData
- HelloSpark
- HelloFlume
- HelloKafka
6.2本地模式新建一个LocalWordCount.scala
右键New------>选择Scala Object:
本地模式,LocalWordCount.scala代码如下:
- import org.apache.spark.SparkConf
- import org.apache.spark.SparkContext
- import org.apache.spark.rdd.RDD
- objectLocalWordCount{
- def main(args:Array[String]){
- /**
- * 第一步:创建Spark的配置对象SparkConf,设置Spark程序的运行时的配置信息,
- * 例如说通过setMaster来设置程序要连接的Spark集群的Master的URL,
- * 如果设置为local,则代表Spark程序在本地运行,特别适合于机器配置条件非常差
- * (例如只有1G的内存)的初学者
- */
- val conf =newSparkConf()//创建SparkConf对象,由于全局只有一个SparkConf所以不需要工厂方法
- conf.setAppName("wow,my first spark app")//设置应用程序的名称,在程序的监控界面可以看得到名称
- conf.setMaster("local")//此时程序在本地运行,不需要安装Spark集群
- /**
- * 第二步:创建SparkContext对象
- * SparkContext是Spark程序所有功能的唯一入口,无论是采用Scala、Java、Python、R等都必须要有一个
- * SparkContext
- * SparkContext核心作用:初始化Spark应用程序运行所需要的核心组件,包括DAGScheduler,TaskScheduler,SchedulerBacked,
- * 同时还会负责Spark程序往Master注册程序等
- * SparkContext是整个Spark应用程序中最为至关重要的一个对象
- */
- val sc=newSparkContext(conf)//创建SpackContext对象,通过传入SparkConf实例来定制Spark运行的具体参数的配置信息
- /**
- * 第三步:根据具体的数据来源(HDFS,HBase,Local,FileSystem,DB,S3)通过SparkContext来创建RDD
- * RDD的创建基本有三种方式,(1)根据外部的数据来源(例如HDFS)(2)根据Scala集合(3)由其它的RDD操作
- * 数据会被RDD划分为成为一系列的Partitions,分配到每个Partition的数据属于一个Task的处理范畴
- */
- //读取本地文件并设置为一个Partition
- val lines=sc.textFile("words.txt",1)//第一个参数为为本地文件路径,第二个参数minPartitions为最小并行度,这里设为1
- //类型推断 ,也可以写下面方式
- // val lines : RDD[String] =sc.textFile("words.txt", 1)
- /**
- * 第四步:对初始的RDD进行Transformation级别的处理,例如map,filter等高阶函数
- * 编程。来进行具体的数据计算
- * 第4.1步:将每一行的字符串拆分成单个的单词
- */
- //对每一行的字符串进行单词拆分并把所有行的结果通过flat合并成一个大的集合
- val words = lines.flatMap { line => line.split(" ")}
- /**
- * 第4.2步在单词拆分的基础上,对每个单词实例计数为1,也就是word=>(word,1)tuple
- */
- val pairs = words.map { word =>(word,1)}
- /**
- * 第4.3步在每个单词实例计数为1的基础之上统计每个单词在文中出现的总次数
- */
- //对相同的key进行value的累加(包括local和Reduce级别的同时Reduce)
- val wordCounts = pairs.reduceByKey(_+_)
- //打印结果
- wordCounts.foreach(wordNumberPair => println(wordNumberPair._1 +":"+wordNumberPair._2))
- //释放资源
- sc.stop()
- }
- }
右键Run As----->Scala Application
运行结果如图:
6.3集群模式新建一个ClusterWordCount.scala
集群模式----ClusterWordCount.scala代码如下:
- import org.apache.spark.SparkConf
- import org.apache.spark.SparkContext
- import org.apache.spark.rdd.RDD
- objectClusterWordCount{
- def main(args:Array[String]){
- /**
- * 第一步:创建Spark的配置对象SparkConf,设置Spark程序的运行时的配置信息,
- * 例如说通过setMaster来设置程序要连接的Spark集群的Master的URL,
- * 如果设置为local,则代表Spark程序在本地运行,特别适合于机器配置条件非常差
- * (例如只有1G的内存)的初学者
- */
- val conf =newSparkConf()//创建SparkConf对象,由于全局只有一个SparkConf所以不需要工厂方法
- conf.setAppName("wow,my first spark app")//设置应用程序的名称,在程序的监控界面可以看得到名称
- //conf.setMaster("spark://192.168.168.200:7077")//此时程序在Spark集群
- /**
- * 第二步:创建SparkContext对象
- * SparkContext是Spark程序所有功能的唯一入口,无论是采用Scala、Java、Python、R等都必须要有一个
- * SparkContext
- * SparkContext核心作用:初始化Spark应用程序运行所需要的核心组件,包括DAGScheduler,TaskScheduler,SchedulerBacked,
- * 同时还会负责Spark程序往Master注册程序等
- * SparkContext是整个Spark应用程序中最为至关重要的一个对象
- */
- val sc=newSparkContext(conf)//创建SpackContext对象,通过传入SparkConf实例来定制Spark运行的具体参数的配置信息
- /**
- * 第三步:根据具体的数据来源(HDFS,HBase,Local,FileSystem,DB,S3)通过SparkContext来创建RDD
- * RDD的创建基本有三种方式,(1)根据外部的数据来源(例如HDFS)(2)根据Scala集合(3)由其它的RDD操作
- * 数据会被RDD划分为成为一系列的Partitions,分配到每个Partition的数据属于一个Task的处理范畴
- */
- //读取HDFS文件并切分成不同的Partition
- val lines=sc.textFile("hdfs://192.168.168.200:9000/input/words.txt")
- //val lines=sc.textFile("/index.html")
- //类型推断 ,也可以写下面方式
- // val lines : RDD[String] =sc.textFile("hdfs://192.168.168.200:9000/input/words.txt", 1)
- /**
- * 第四步:对初始的RDD进行Transformation级别的处理,例如map,filter等高阶函数
- * 编程。来进行具体的数据计算
- * 第4.1步:将每一行的字符串拆分成单个的单词
- */
- //对每一行的字符串进行单词拆分并把所有行的结果通过flat合并成一个大的集合
- val words = lines.flatMap { line => line.split(" ")}
- /**
- * 第4.2步在单词拆分的基础上,对每个单词实例计数为1,也就是word=>(word,1)tuple
- */
- val pairs = words.map { word =>(word,1)}
- /**
- * 第4.3步在每个单词实例计数为1的基础之上统计每个单词在文中出现的总次数
- */
- //对相同的key进行value的累加(包括local和Reduce级别的同时Reduce)
- val wordCounts = pairs.reduceByKey(_+_)
- //打印结果
- wordCounts.collect.foreach(wordNumberPair => println(wordNumberPair._1 +":"+wordNumberPair._2))
- //释放资源
- sc.stop()
- }
- }
集群模式要运行在Spark集群环境下(Linux系统中)
打包 :右击、export、Java 、jar File
确保hdfs://192.168.168.200:9000/input/words.txt路径文件存在。
- cd /usr/local/spark/spark-2.1.1-bin-hadoop2.7
- bin/spark-submit --class"ClusterWordCount"--master local[4] myApp/TestSpark.jar
集群模式运行成功!
scala IDE for Eclipse开发Spark程序的更多相关文章
- 使用Scala IDE for Eclipse遇到build errors错误的解决办法
在编写第一个Scala语言的Spark程序时,在Scala IDE for Eclipse中运行程序时出现“Project XXXX contains build errors, Continue l ...
- ubuntu下eclipse scala开发插件(Scala IDE for Eclipse)安装
1. 环境介绍 系统:ubuntu16.04(不过和系统版本关系不大) elipse:Neon.1aRelease (4.6.1) 2. 插件介绍 Scala IDE for eclipse是elip ...
- CentOS6.5下如何正确下载、安装Intellij IDEA、Scala、Scala-intellij-bin插件、Scala IDE for Eclipse助推大数据开发(图文详解)
不多说,直接上干货! 第一步:卸载CentOS中自带openjdk Centos 6.5下的OPENJDK卸载和SUN的JDK安装.环境变量配置 第二步:安装Intellij IDEA 若是3节点 ...
- Scala IDE for Eclipse的下载、安装和WordCount的初步使用(本地模式和集群模式)
包括: Scala IDE for Eclipse的下载 Scala IDE for Eclipse的安装 本地模式或集群模式 我们知道,对于开发而言,IDE是有很多个选择的版本.如我们大部分人经常 ...
- eclipse运行spark程序时日志颜色为黑色的解决办法
自从开始学习spark计算框架以来,我们老师教的是local模式下用eclipse运行spark程序,然后我在运行spark程序时,发现控制台的日志颜色总是显示为黑色,哇,作为程序猿总有一种强迫症,发 ...
- windows环境下Eclipse开发MapReduce程序遇到的四个问题及解决办法
按此文章<Hadoop集群(第7期)_Eclipse开发环境设置>进行MapReduce开发环境搭建的过程中遇到一些问题,饶了一些弯路,解决办法记录在此: 文档目的: 记录windows环 ...
- Eclipse开发Android程序如何在手机上运行
android开发不论是在真机上调试还是最终发布到真机上都非常简单,过程如下: 1.安装usb驱动 手机要能与电脑相连,当然要安驱动了.效果就是你插入手机,电脑显示驱动已识别.驱动安装的官方教程:ht ...
- Eclipse开发JavaWeb程序报Server Tomcat v7.0 at localhost was unable to start
出处:http://www.javaweb1024.com/info/582.jspx 原因重现: Eclipse开发JavaWeb程序,启动Servers的Tomcat服务器,突然跳出弹出框,内容显 ...
- [b0007] windows 下 eclipse 开发 hdfs程序样例
目的: 学习使用hdfs 的java命令操作 相关: 进化: [b0010] windows 下 eclipse 开发 hdfs程序样例 (二) [b0011] windows 下 eclipse 开 ...
随机推荐
- Ubantu-Nginx部署
nginx+uwsgi+django部署流程 当我们在用django开发的web项目时,开发测试过程中用到的是django自带的测试服务器,由于其安全及稳定等性能方面的局限性,django官方并不 ...
- OSPF路由协议(一)
实验要求:使用OSPF协议,使各个PC之间能够相互通信 拓扑如下: 配置如下: R1enableconfigure terminal interface f0/0ip address 192.168. ...
- 单交换机划分VLAN配置
实验要求:相同vlan的主机能够通信,不同vlan的主机不能通讯 拓扑如下: 涉及内容有: 1.端口trunk模式设置 2.VTP的创建和设置 3.vlan的划分 配置如下: A enable 进入特 ...
- RAC环境修改参数生效测试
本篇文档--目的:实验测试在RAC环境下,修改数据库参数与单实例相比,需要注意的地方 --举例说明,在实际生产环境下,以下参数很可能会需要修改 --在安装数据库完成后,很可能没有标准化,初始化文档,没 ...
- maven工程的多环境配置方案(profile)
前言: 写一篇水文来打发下时间吧^_^. 在应用开发中, 总会遇到开发/测试/预发布/线上环境, 其环境不同, 其具体的配置项也有所不同, 因此如何快速的切换各个环境配置, 进行打包配置, 成了一个小 ...
- pytorch使用tensorboardX进行网络可视化
我们知道,对于pytorch上的搭建动态图的代码的可读性非常高,实际上对于一些比较简单的网络,比如alexnet,vgg阅读起来就能够脑补它们的网络结构,但是对于比较复杂的网络,如unet,直接从代码 ...
- URL diff URI
很多人会混淆这两个名词. URL:(Uniform/Universal Resource Locator 的缩写,统一资源定位符). URI:(Uniform Resource Identifier ...
- pip3 install scrap报错
mac系统 pip3 install scrapy 失败 No local packages or working download links found for incremental>=1 ...
- 【HDOJ1051】【排序+LIS】【贪心】
http://acm.hdu.edu.cn/showproblem.php?pid=1051 Wooden Sticks Time Limit: 2000/1000 MS (Java/Others) ...
- 《DSP using MATLAB》Problem 5.18
代码: %% ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ %% O ...