导航

IDEA非sbt下spark开发

Posted on 2016-03-05 11:04  ggzone  阅读(201)  评论(0编辑  收藏  举报
  • 创建非sbt的scala项目
  • 引入spark的jar包
File->Project Structure->Libararies引用spark-assembly-1.5.2-hadoop2.6.0.jar
  • 编写代码
import scala.math.random
import org.apache.spark._
/**
 * Created by code-pc on 16/3/2.
  */
object test1 {
  def main(args: Array[String]) {
    val conf = new SparkConf().setAppName("Spark Pi").setMaster("local")
    val spark = new SparkContext(conf)
    val slices = if (args.length > 0) args(0).toInt else 2
    val n = 100000 * slices
    val count = spark.parallelize(1 to n, slices).map { i =>
      val x = random * 2 - 1
      val y = random * 2 - 1
      if (x*x + y*y < 1) 1 else 0
    }.reduce(_ + _)
    println("Pi is roughly " + 4.0 * count / n)
    spark.stop()
  }
}
  • 编译jar包
File -> Project Structure -> Artifacts  -> + -> Jars -> From moudles with dependencies
菜单栏:build Artifacts
  • 运行
./spark-submit --class test1 --master local ~/IdeaProjects/test1/out/artifacts/Pi/test1.jar