热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

WordCount流程(sparksubmit)

一、操作流程(1)构建maven项目①选择maven项目,将ProjectSDK设置为1.8,然后从Createformarchetype中选择scala-archetype-

一、操作流程
(1)构建maven项目
①选择maven项目,将Project SDK设置为1.8,然后从Create form archetype中选择scala-archetype-empty-RELEASE
在这里插入图片描述

②命名Project,然后将GroupId修改为org.flowpp(可选,此处为与flow公司的操作相一致),其他不需要修改
在这里插入图片描述

③选择maven版本,可直接选择本地下载安装的maven版本(maven3.6.1),其他参数不需要修改,即可创建项目。
在这里插入图片描述

(2)导入工作
scala SDK到Project Structure中的Global Libraries当中
设置project SDK为jdk1.8
在这里插入图片描述
在这里插入图片描述

(3)配置POM.xml文件,设置、、、
除了基础设置之外,其他可以沿用相同的代码架构
4.0.0
org.flowpp
demo
1.0-SNAPSHOT
2008

(4)逻辑代码书写
package com.flowpp.demo
import org.apache.spark.SparkConf
import org.apache.spark.sql.SparkSession
object Demo {
def main(args: Array[String]): Unit = {
// val cOnf= new SparkConf().setAppName(“Demo”).setMaster(“local[*]”)
val cOnf= new SparkConf().setAppName(“Demo”)
val ss = SparkSession.builder().config(conf).enableHiveSupport().getOrCreate()
ss.sparkContext.setLogLevel(“error”)
val input = ss.sparkContext.textFile(“tmp/demo/wordcount.txt”)
val words = input.flatMap(line => line.split(" “))
val counts = words.map(word => (word, 1)).reduceByKey{case (x, y) => x + y}
// counts.saveAsTextFile(”")
// counts.foreach(line => println(line._1 + “:” + line._2))
counts.collect().foreach(line => println(line._1 + “:” + line._2))
ss.close()
}
}

(5)Maven操作:clean(清楚编译后目录,默认是target目录)、package(接受编译好的代码,打包成可发布的格式,如JAR)
在这里插入图片描述

maven打包操作完成过后,若项目生成target文件夹,并含如图所示的子文件夹和文件即可,特别是文件test-1.0-SNAPSHOT.jar,咱们可以打开该文件,查看文件内容

可重点关注MANIFEST.MF中的代码
(6)上传test-1.0-SNAPSHOT.jar至服务器本地
(7)spark-submit运行jar包
(8)利用Ambari网页界面后台观看HDFS和YARN的使用情况(主要),也可以借助Spark-2的History选项来观察历史运行记录

二、学习心得
1、spark-submit:主要是要将该代码的jar包提交到spark后来进行运行,因此本机上的JDK(1.8)、Scala(2.11.12)、Hadoop(2.7.1)需要与集群中的软件包版本保持一致
2、spark-shell:交互式程序运行,可以实时查看到代码的运行结果,与spark-submit不同之处在于spark-submit提交整个代码包,而spark-shell则依次提交结果;相同点在于均能实现相关的功能。

三、问题解决
(1)Mavens 无法打包
①注意版本:JDK(1.8)、Scala(2.11.12)、Hadoop(2.7.1)
②POM.xml文件配置:可参考文件POM模板(针对scala2.11.12).txt
4.0.0
org.flowpp
demo
1.0-SNAPSHOT
仅需要修改以上参数,该类参数在maven项目创建完成之后,即可生成相关参数
(2)spark-submit打包过程出现问题
[work@master ~]$ spark-submit demo-1.0-SNAPSHOT.jar
Error: No main class set in JAR; please specify one with --class
Run with --help for usage help or --verbose for debug output
在spark使用过程中,由于spark的底层代码由java(scala)组成,与java的代码运行机制类似,在运行过程中需要指定主类,否则无法正常执行
解决方法一:Maven指定class打包:配置方法
在POM.xml中的添加以下设置
maven-jar-plugin
3.0.2

com.flowpp.demo.Demo
true
lib/


解决方法二:spark-submit参数设置,如下所示
spark-submit --clsaa com.flowpp.demo.Demo demo-1.0-SNAPSHOT.jar
参数优先级:命令行设置>pom文件设置>maven默认参数
关于com.flowpp.demo.Demo的理解:可理解成路径
(3)test文件夹中的代码运行报错
如test/scala文件的scala运行报错的话,可以直接将这部分代码删掉

四、其他
1、文件权限:LINUX和HDFS遵循的文件权限协议posix,可系统地了解相关操作;
2、用户权限:在利用hdfs操作文件时,若出现文件的相关操作,可通过更改用户来进行相应操作,常利用命令sudo su hdfs进行,操作完成之后,调整回work目录,该问题在Hive创建数据表时出现过;
3、jar相关操作


推荐阅读
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • Java自带的观察者模式及实现方法详解
    本文介绍了Java自带的观察者模式,包括Observer和Observable对象的定义和使用方法。通过添加观察者和设置内部标志位,当被观察者中的事件发生变化时,通知观察者对象并执行相应的操作。实现观察者模式非常简单,只需继承Observable类和实现Observer接口即可。详情请参考Java官方api文档。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 关键词:Golang, Cookie, 跟踪位置, net/http/cookiejar, package main, golang.org/x/net/publicsuffix, io/ioutil, log, net/http, net/http/cookiejar ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 本文介绍了在多平台下进行条件编译的必要性,以及具体的实现方法。通过示例代码展示了如何使用条件编译来实现不同平台的功能。最后总结了只要接口相同,不同平台下的编译运行结果也会相同。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • Spring学习(4):Spring管理对象之间的关联关系
    本文是关于Spring学习的第四篇文章,讲述了Spring框架中管理对象之间的关联关系。文章介绍了MessageService类和MessagePrinter类的实现,并解释了它们之间的关联关系。通过学习本文,读者可以了解Spring框架中对象之间的关联关系的概念和实现方式。 ... [详细]
author-avatar
锦瑟刻下两段缠绵
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有