超詳細(xì)的使用Intellij IDEA+Maven開發(fā)Spark項(xiàng)目的流程

上了數(shù)據(jù)挖掘的課凿宾,要寫結(jié)課論文了矾屯。于是選擇了Spark作為自己的課程主題,也是為自己之后的畢業(yè)論文打下知識基礎(chǔ)初厚,這里將自己的第一試驗(yàn)記錄下來问拘,以便之后的回顧。

1.環(huán)境配置

這是我的開發(fā)環(huán)境:

  • Windows 10
  • 阿里云(Centos 7.3)
  • spark-2.2.0-bin-hadoop2.7(scala-compiler-2.11.8.jar)
  • Scala 2.12.4(這個需要跟spark-2.2.0-bin-hadoop2.7中Scala的編譯版本一樣才會執(zhí)行成功惧所,之后會看到報(bào)錯骤坐,所以這個改為Scala 2.11.8)

2.配置Spark的運(yùn)行環(huán)境(Linux)

重點(diǎn):Spark的版本一定要注意和Scala的版本相對應(yīng),不然出現(xiàn)的錯誤會千奇百怪的下愈,請謹(jǐn)慎安裝纽绍,具體的對應(yīng)安裝版本無法詳細(xì),在這里只能給出自己嘗試過的安裝版本

安裝的環(huán)境的前提是要安裝JDK(建議是1.8)势似,因?yàn)镾park程序是運(yùn)行在JVM上的拌夏,安裝Spark只需要將壓縮包解壓即可僧著。(這是我見過的最簡單的安裝啦啦啦)下面的是安裝后的Spark目錄:

image.png

可以利用命令行寫Spark項(xiàng)目,可以利用Python和Scala語言寫(建議使用Scala)障簿,使用./spark-shell 進(jìn)入編寫的入口:

image.png

配置免密鑰登錄

第一步:使用下面的命令生成密鑰

$ ssh-keygen -t rsa

如果之前的生成的密鑰的話盹愚,在這里可以不用生成。

第二步:復(fù)制公鑰文件

進(jìn)入/root/.ssh/ 目錄站故,如果沒有authorized_keys 文件皆怕,可以先創(chuàng)建一個此文件。

$ cat id_rsa.pub  >> authorized_keys

第三步:修改authorized_keys文件的權(quán)限

$ chmod 600 authorized_keys 

第四步:驗(yàn)證ssh服務(wù)

$ ssh localhost

執(zhí)行上述命令如果沒有輸入密碼就可以登錄就說明成功了!

3.Intellij IDEA上安裝Scala插件和新建項(xiàng)目(Windows)

下面是網(wǎng)友項(xiàng)目的插件安裝方法和新建簡單的Scala項(xiàng)目,搬過來給大家看看蔬浙,鏈接如下:

不會停的蝸牛

下面是我新建Scala項(xiàng)目的目錄結(jié)構(gòu)圖:

image.png

重點(diǎn):在build.sbt 文件中添加libraryDependencies 的版本問題,這也是依賴版本要對應(yīng)的問題虱黄,后面會介紹利用Maven管理依賴,這樣會方便多了吮成。

4.編寫第一個Spark程序

這是非常重要的一步:編寫spark程序時需要提前將Scala的SDK添加到Global Libraries,如下圖所示:

image.png

新建Scala的class類:

image.png

添加依賴(官方介紹):

可以像這樣定義一個依賴橱乱,其中 groupIdartifactIdrevision 都是字符串:

libraryDependencies += groupID % artifactID % revision

或者像這樣粱甫, 用字符串或者 Configuration val 當(dāng)做 configuration

libraryDependencies += groupID % artifactID % revision % configuration

方法 % 從字符串創(chuàng)建 ModuleID 對象仅醇,然后將 ModuleID 添加到 libraryDependencies 中。

當(dāng)然魔种,要讓 sbt(通過 Ivy)知道從哪里下載模塊。如果你的模塊和 sbt 來自相同的某個默認(rèn)的倉庫粉洼,這樣就會工作节预。例如,Apache Derby 在標(biāo)準(zhǔn)的 Maven2 倉庫中:

libraryDependencies += "org.apache.derby" % "derby" % "10.4.1.3"
image.png

不推薦使用這用手動添加依賴的方式属韧,推薦使用Maven管理依賴的方法安拟,請往下面看。

5.將Spark程序打包(Jar包)

打包設(shè)置選項(xiàng):

image.png

打包參數(shù)設(shè)置:1.選擇主函數(shù)宵喂;2.選擇只打包Scala程序

image.png

Build 中選擇Build Artifacts 后選擇build即可打包成功

image.png

選擇build 糠赦,然后等待打包結(jié)束

image.png

打包的jar包的位置:

image.png

將jar包利用XFtp工具上傳到Spark運(yùn)行環(huán)境(對應(yīng)程序運(yùn)行地址):

image.png

6.將Jar包上傳至Spark運(yùn)行環(huán)境并啟動和運(yùn)行

啟動Spark運(yùn)行環(huán)境需要依次執(zhí)行下面三個命令:

在執(zhí)行了master進(jìn)程和worker進(jìn)程后,可以執(zhí)行curl 127.0.0.1:8080 得到Spark Master at spark://MJ:7077 锅棕,注意這個地址每個機(jī)器上都是不一樣的拙泽,注意區(qū)分一下。

Spark Master at spark://MJ:7077

#啟動master進(jìn)程
./sbin/start-master.sh
#啟動worker進(jìn)程
./bin/spark-class org.apache.spark.deploy.worker.Worker spark://MJ:7077

#提交作業(yè) master后面的地址通過localhost:8080得到  class后面的是自己的項(xiàng)目的名稱和對應(yīng)jar包的地址
./bin/spark-submit --master spark://MJ:7077  --class WordCount  /home/MJ/spark/hellospark.jar

7.查看Spark運(yùn)行的結(jié)果

提交作業(yè)之后裸燎,可以查看作業(yè)運(yùn)行的結(jié)果:

image.png

8.構(gòu)建Maven管理Spark項(xiàng)目

首先是New Project 項(xiàng)目選擇Maven顾瞻,JDK選擇最好是1.8+,然后點(diǎn)擊next:

image.png

新建項(xiàng)目之后的目錄結(jié)構(gòu)是這樣的:

image.png

把其中的java和test文件夾都重新命名為scala文件夾德绿,如下圖

image.png

右鍵項(xiàng)目名出現(xiàn)Add Frameworks support 荷荤,并選擇scala:

image.png
image.png

選擇之后退渗,然后新建一個Package 包文件夾,最后就是新建scala文件

image.png

新建一個Main 文件蕴纳,打印出hello spark! 字樣

image.png
image.png

添加必要的關(guān)于Spark的pom 文件会油,點(diǎn)擊添加Group: org.apache.spark

Spark Project Core

<!-- https://mvnrepository.com/artifact/org.apache.spark/spark-core -->
<dependency>
    <groupId>org.apache.spark</groupId>
    <artifactId>spark-core_2.11</artifactId>
    <version>2.2.1</version>
</dependency>

Spark Project SQL

<!-- https://mvnrepository.com/artifact/org.apache.spark/spark-sql -->
<dependency>
    <groupId>org.apache.spark</groupId>
    <artifactId>spark-sql_2.11</artifactId>
    <version>2.2.1</version>
</dependency>

Spark Project Hive

<!-- https://mvnrepository.com/artifact/org.apache.spark/spark-hive -->
<dependency>
    <groupId>org.apache.spark</groupId>
    <artifactId>spark-hive_2.11</artifactId>
    <version>2.2.1</version>
</dependency>

9.可能出現(xiàn)的問題

出現(xiàn)這種情況是由于在IDEA和Linux中安裝的Scala版本不一樣,把兩者選擇成一樣的就會編譯通過古毛。

image.png

http://blog.csdn.net/u013054888/article/details/54600229

進(jìn)入/usr/local/spark-2.2.0-bin-hadoop2.7/jars 找到Scala編譯的版本號:

image.png

在IDEA中的Project Structure中選擇對應(yīng)的Scala版本:

image.png

出現(xiàn)下面錯誤:
exception in thread main org.apache.spark.sparkexception:A master URL must be set in your..
從提示中可以看出找不到程序運(yùn)行的master翻翩,此時需要配置環(huán)境變量。
傳遞給spark的master url可以有如下幾種:

local 本地單線程
local[K] 本地多線程(指定K個內(nèi)核)
local[*] 本地多線程(指定所有可用內(nèi)核)
spark://HOST:PORT 連接到指定的 Spark standalone cluster master喇潘,需要指定端口体斩。
mesos://HOST:PORT 連接到指定的 Mesos 集群,需要指定端口颖低。
yarn-client客戶端模式 連接到 YARN 集群絮吵。需要配置 HADOOP_CONF_DIR。
yarn-cluster集群模式 連接到 YARN 集群忱屑。需要配置 HADOOP_CONF_DIR蹬敲。
點(diǎn)擊edit configuration,在左側(cè)點(diǎn)擊該項(xiàng)目莺戒。在右側(cè)在右側(cè)VM options中輸入“-Dspark.master=local”伴嗡,指示本程序本地單線程運(yùn)行,再次運(yùn)行即可从铲。從提示中可以看出找不到程序運(yùn)行的master瘪校,此時需要配置環(huán)境變量。

點(diǎn)擊edit configuration名段,在左側(cè)點(diǎn)擊該項(xiàng)目阱扬。在右側(cè)

在右側(cè)VM options中輸入“-Dspark.master=local”

,指示本程序本地單線程運(yùn)行伸辟,再次運(yùn)行即可麻惶。

image.png

運(yùn)行成功的結(jié)果:


image.png

10.參考資料

http://docs.scala-lang.org/getting-started.html

http://www.reibang.com/p/ecc6eb298b8f

http://www.reibang.com/p/7c0d22847548

http://blog.csdn.net/u012373815/article/details/53266301

http://www.scala-sbt.org/1.x/docs/zh-cn/Library-Dependencies.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市信夫,隨后出現(xiàn)的幾起案子窃蹋,更是在濱河造成了極大的恐慌,老刑警劉巖静稻,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件警没,死亡現(xiàn)場離奇詭異,居然都是意外死亡振湾,警方通過查閱死者的電腦和手機(jī)惠奸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來恰梢,“玉大人佛南,你說我怎么就攤上這事梗掰。” “怎么了嗅回?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵及穗,是天一觀的道長。 經(jīng)常有香客問我绵载,道長埂陆,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任娃豹,我火速辦了婚禮焚虱,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘懂版。我一直安慰自己鹃栽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布躯畴。 她就那樣靜靜地躺著民鼓,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蓬抄。 梳的紋絲不亂的頭發(fā)上丰嘉,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天,我揣著相機(jī)與錄音嚷缭,去河邊找鬼饮亏。 笑死,一個胖子當(dāng)著我的面吹牛阅爽,可吹牛的內(nèi)容都是我干的路幸。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼优床,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了誓焦?” 一聲冷哼從身側(cè)響起胆敞,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎杂伟,沒想到半個月后移层,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡赫粥,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年观话,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片越平。...
    茶點(diǎn)故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡频蛔,死狀恐怖灵迫,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情晦溪,我是刑警寧澤瀑粥,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站三圆,受9級特大地震影響狞换,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜舟肉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一修噪、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧路媚,春花似錦黄琼、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至院领,卻和暖如春弛矛,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背比然。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工丈氓, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人强法。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓万俗,卻偏偏與公主長得像,于是被迫代替她去往敵國和親饮怯。 傳聞我的和親對象是個殘疾皇子闰歪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評論 2 348

推薦閱讀更多精彩內(nèi)容