日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

命令行中只用scala来运行一个spark应用

發布時間:2023/12/20 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 命令行中只用scala来运行一个spark应用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

由于intellij十分消耗內存,

并且在概念上來講,scala導入jar包應該和在集成開發環境中導入jar包是等效的。

所以我想,能否純命令行,不用spark-submit的情況下來運行呢?

折騰了好幾個小時,方案如下。

TestRdd.scala代碼:

import scala.Iteratorimport org.apache.spark.SparkConf import org.apache.spark.SparkContext import org.apache.spark.sql.{DataFrame, SparkSession}import org.apache.log4j.Logger import org.apache.log4j.Levelobject TestRdd {def sumOfEveryPartition(input: Iterator[Int]): Int = {var total = 0input.foreach { elem =>total += elem}total}def main(args: Array[String]) {// val conf = new SparkConf().setAppName("Spark Rdd Test")// val spark = new SparkContext(conf)Logger.getLogger("org").setLevel(Level.OFF)Logger.getLogger("akka").setLevel(Level.OFF)Logger.getRootLogger().setLevel(Level.ERROR) val spark = SparkSession.builder.appName("Intro").config("spark.master", "local").getOrCreate();spark.sparkContext.setLogLevel("ERROR")val input = spark.sparkContext.parallelize(List(1, 2, 3, 4, 5, 6), 2)//RDD有6個元素,分成2個partitionval result = input.mapPartitions(partition => Iterator(sumOfEveryPartition(partition)))//partition是傳入的參數,是個list,要求返回也是list,即Iterator(sumOfEveryPartition(partition))result.collect().foreach {println(_)//6 15}spark.stop()} }

運行方法:

scala -classpath $(echo *.jar ~/bigdata/spark-2.3.1-bin-hadoop2.7/jars/*.jar| tr ' ' ':') TestRdd.scala

運行結果:
6
15

?

注意:上面導入了spark本地部署中的所有jars包
?

?


?

總結

以上是生活随笔為你收集整理的命令行中只用scala来运行一个spark应用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。