如何在IDEA中编写Spark程序

环境搭建

  1. 创建Maven项目
  • 添加Spark依赖(在 pom.xml 中):

<dependency>

<groupId>org.apache.spark</groupId>

<artifactId>spark-core_2.12</artifactId>

<version>3.5.0</version>

</dependency>

  1. 配置Scala SDK
  • 在IDEA中安装Scala插件,设置项目SDK为Scala版本(如2.12)

编写第一个Spark程序

  1. 创建Scala类

import org.apache.spark.{SparkConf, SparkContext}

object SparkWordCount {

def main(args: Array[String]): Unit = {

val conf = new SparkConf().setAppName("WordCount").setMaster("local[*]")

val sc = new SparkContext(conf)

val text = sc.textFile("input.txt")

val words = text.flatMap(_.split(" "))

val counts = words.map(word => (word, 1)).reduceByKey(_ + _)

counts.saveAsTextFile("output")

sc.stop()

}

}

运行与调试

  • 本地调试:设置 setMaster("local[*]") ,直接在IDEA中运行主类。

  • 提交到集群:

  1. 打包项目为JAR(Maven的 package 命令)。

  2. 执行命令:

spark-submit --master yarn --class SparkWordCount /path/to/your.jar hdfs://input.txt

常见问题

  • 依赖冲突:确保Spark和Hadoop版本兼容,使用 provided scope排除冲突依赖。

  • 日志配置:在 src/main/resources 添加 log4j.properties ,简化日志输出。

相关推荐
雷工笔记23 分钟前
【软件安装】VScode介绍安装步骤及中文界面设置方法
ide·vscode·编辑器
gaog2zh11 小时前
100202Title和Input组件_编辑器-react-仿低代码平台项目
react.js·低代码·编辑器
一瞬祈望1 天前
Visual Studio Code 基础设置指南
vscode·编辑器
hfut02882 天前
【vscode使用说明】
vscode·编辑器·vim
不老刘2 天前
Tiptap(基于 Prosemirror)vs TinyMCE:哪个更适合你的技术栈?
编辑器·tinymce·tiptap·prosemirror
BIBI20492 天前
自定义 VSCode 标题栏以区分不同版本
ide·vscode·编辑器
_Chipen2 天前
lazy_vim_cmake_clangd_从零到自动补全与语法检查
linux·编辑器·vim
QL.ql4 天前
vscode的ws环境,esp32s3连接wifi
ide·vscode·编辑器
_错错错4 天前
Vim 常用快捷键及插件
编辑器·vim·linux 开发工具
大白同学4214 天前
【Linux】编辑器vim的使用
linux·编辑器·vim