sbt安装

一、sbt介绍

在Spark中,sbt(Scala Build Tool)是一个用于构建Scala项目的工具。它是Spark项目的主要构建工具之一,用于编译Scala代码、管理依赖项、打包应用程序以及执行其他与项目构建相关的任务。

sbt的用途在Spark开发中主要体现在以下几个方面:

  • 编译代码:sbt可以编译Scala源代码文件(.scala)和Java源代码文件(.java),生成字节码文件(.class)。

  • 管理依赖:sbt允许你声明项目的外部依赖,并自动下载和解析这些依赖。在Spark项目中,这包括对Spark框架的依赖,以及其他可能使用的库,如Kafka、Hadoop等。

  • 打包应用程序:sbt可以创建可运行的JAR包,这些包可以在Spark集群上分发和运行。这对于将Spark应用程序部署到生产环境非常重要。

  • 运行和测试:sbt可以运行主类,执行单元测试,以及进行其他与项目相关的任务。

  • 插件和扩展:sbt支持插件,这意味着你可以扩展sbt的功能,以满足特定的构建需求。例如,使用sbt-assembly插件来创建一个“胖JAR”(uber JAR),其中包含了项目的所有依赖项。

  • 缓存和增量编译:sbt会缓存编译结果,这意味着在后续的构建中,只有更改过的源文件会被重新编译,从而加快构建速度。

  • 多项目构建:sbt支持多项目构建,允许你在一个构建配置中管理多个相关项目,这对于大型项目和应用程序来说非常有用。

在Spark项目中,sbt通常与项目的主构建文件 build.sbt 配合使用,该文件定义了项目的元数据、依赖关系和构建配置。通过在sbt的交互式界面中运行命令,或者通过sbt的批处理模式,你可以执行各种构建任务。

二、下载后的安装包sbt-1.9.0.tgz保存在了根目录下

下载链接:Download | sbt (scala-sbt.org)

cd ~
sudo tar -zxvf ./sbt-1.9.0.tgz -C /usr/local 
cd /usr/local/sbt
sudo chown -R hadoop /usr/local/sbt     # 此处的hadoop为系统当前用户名
cp ./bin/sbt-launch.jar ./  #把bin目录下的sbt-launch.jar复制到sbt安装目录下

三、接着在安装目录中使用下面命令创建一个Shell脚本文件,用于启动sbt:

vim /usr/local/sbt/sbt

该脚本文件中的代码如下:

#!/bin/bash
SBT_OPTS="-Xms512M -Xmx1536M -Xss1M -XX:+CMSClassUnloadingEnabled -XX:MaxPermSize=256M"
java $SBT_OPTS -jar `dirname $0`/sbt-launch.jar "$@"

保存后,为该Shell脚本文件增加可执行权限:

chmod u+x /usr/local/sbt/sbt

三、使用如下命令查看sbt版本信息:

cd /usr/local/sbt
./sbt sbtVersion

可以使用如下命令查看sbt版本信息:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/10837.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于Nios软件实现流水灯+串口输出

基于NIOS-II软核实现流水灯串口输出 引言: ​ 在现代电子设计领域,FPGA(现场可编程门阵列)因其灵活性和并行处理能力而成为实现复杂数字系统的首选平台。Nios II,作为Altera(现为Intel旗下)提供…

算法训练Day26 | 332.重新安排行程 ● 51. N皇后 ● 37. 解数独

332.重新安排行程 class Solution { public:vector<string> result;bool backtracking(vector<vector<string>>& tickets, vector<bool>& used){if(result.size()tickets.size()1){return true;}for(int i0; i<tickets.size(); i){if(used…

重生之我要精通JAVA--第四周笔记

文章目录 接口接口的定义与使用接口中成员的特点接口和类之间的关系 JDK9新增的方法适配器设计模式 内部类什么是内部类&#xff1f;内部类的访问特点分类成员内部类获取成员内部类对象 静态内部类局部内部类匿名内部类格式细节使用场景 APIMathMath常用方法 SystemRuntimeObje…

ts 详细-学习

TS基础&#xff08;一&#xff09; 变量声明 ts的类型主要包括两种数据类型&#xff1a;原始数据类型和对象数据类型 原始数据类型和js的数据类型相似包括以下几种&#xff1a;布尔值&#xff0c;字符串&#xff0c;null,undefined以及Se6中的Symbol和BigInt的原址数据类型 …

VMware虚拟机故障:“显示指定的文件不是虚拟磁盘“,处理办法

一、故障现象 由于虚拟机宕机&#xff0c;强制重新启动虚拟机后显示错误&#xff0c;没有办法启动虚拟机。 虚拟机有快照&#xff0c;执行快照还原&#xff0c;结果也不行&#xff0c;反复操作&#xff0c;在虚拟机文件目录出现很多莫名文件 二、故障原因 根据故障提示&#…

数据结构(C):玩转链表

目录 &#x1f37a;0.前言 1.链表的概念 2.链表的分类 2.1带头不带头 2.2单向和双向 2.3循环和不循环 2.4主要使用的链表 3.链表的实现 3.1申请一个链表 3.2头插和尾插 3.2.1函数的形参问题 3.2.2二级指针问题解决 3.3头删和尾删 3.4打印链表 3.5查找 3.5销…

MySQL视图:数据库中的虚拟表与数据透视窗

前言 在数据库管理系统的世界里&#xff0c;MySQL视图扮演着一个独特而重要的角色&#xff0c;它如同数据库中的一扇窗&#xff0c;透过这扇窗&#xff0c;我们可以以不同的视角观察和操作数据&#xff0c;而无需直接触及底层表格的结构。本文将为您深入解析MySQL视图的定义、…

【谷粒商城】03创建商品模块

1.创建模块 2.创建项目微服务 商品服务、仓储服务、订单服务、优惠券服务、用户服务 共同&#xff1a; 1&#xff09;、web、openfeign 2&#xff09;、每一个服务&#xff0c;包名 com.atguigu.gulimall.xxx(product/order/ware/coupon/member) 3&#xff09;、模块名&#x…

​《MATLAB科研绘图与学术图表绘制从入门到精通》示例:绘制德国每日风能和太阳能产量3D线图

在MATLAB中&#xff0c;要绘制3D线图&#xff0c;可以使用 plot3 函数。 在《MATLAB科研绘图与学术图表绘制从入门到精通》书中通过绘制德国每日风能和太阳能产量3D线图解释了如何在MATLAB中绘制3D线图。 购书地址&#xff1a;https://item.jd.com/14102657.html

future wait_for()成员、shared_future

future wait_for()成员 wait_for()&#xff1a;等待其异步操作操作完成或者超出等待&#xff0c;用于检查异步操作的状态。wait_for()可以接受一个std::chrono::duration类型的参数&#xff0c;它表示等待的最大时间&#xff0c;会返回一个std::future_status枚举值&#xff0…

完美解决Windows10下-更换JDK环境变量后,在cmd下执行仍java -version然出现原来版本的JDK的问题

一、错误场景预演 本人欲将 JDK 1.8 通过安装包的方式升级为 JDK 22。 本地旧版本&#xff1a;1.8.0_221预升级版本&#xff1a;22.0.1 1.1、查看本地旧版本 在配置环境变量之前&#xff0c;首先我们要明确&#xff0c;本地存在旧版本&#xff0c;如果本地没有 Java&#x…

MFC通过继承现有控件自定义控件

在MFC 自定义控件&#xff0c;可以通过继承MFC提供的控件类&#xff08;如CButton、CEdit、CListBox等&#xff09;并重写其成员函数和消息处理函数来实现。 以下是一个基本的步骤指南&#xff0c;用于在MFC中创建自定义控件&#xff1a; 确定要继承的基类&#xff1a; 首先…

vm16安装最新版本的ubuntu虚拟机,并安装g++的步骤记录

背景 低版本的ubuntu安装G一直不成功&#xff0c;干脆安装最新版的 官网下载 bing搜索ubuntu 下载完成 vm16新建虚拟机 一直下一步&#xff0c;安装完成 终端输入命令 sudo apt-get update ᅟᅠ       sudo apt install gcc ᅟᅠ      sudo apt install g

树莓派点亮FPGA小灯

树莓派点亮FPGA小灯 引言&#xff1a; ​ 本次实验的目的是通过树莓派和FPGA之间的串口通信&#xff0c;控制FPGA开发板上的小灯。实验将展示如何使用树莓派发送特定的字符信号&#xff0c;通过串口传输至FPGA&#xff0c;并在FPGA上实现逻辑解析&#xff0c;以点亮指定的小灯。…

Vim常用快捷键

这个是我的草稿本记录一下防止丢失&#xff0c;以后有时间进行整理 0 或功能键[Home]这是数字『 0 』&#xff1a;移动到这一行的最前面字符处 (常用)$ 或功能键[End]移动到这一行的最后面字符处(常用)G移动到这个档案的最后一行(常用)nGn 为数字。移动到这个档案的第 n 行。例…

【QT】QT背景介绍

本专栏内容为&#xff1a;QT学习专栏 通过本专栏的深入学习&#xff0c;你可以了解并掌握QT。 &#x1f493;博主csdn个人主页&#xff1a;小小unicorn ⏩专栏分类&#xff1a;QT &#x1f69a;代码仓库&#xff1a;小小unicorn的代码仓库&#x1f69a; &#x1f339;&#x1f…

灰度图恢复(C++)

思路&#xff0c;数字出现的次数与要统计的行列向匹配&#xff0c;函数表达式为 sum row*mcol 1; 例如初始出现次数为255 2&#xff0c;即255出现2次&#xff0c;则{0&#xff0c;0}、{0&#xff0c;1}都为255 #include <iostream> #include <sstream> #include…

3D分子生成的定制扩散框架 MolDiff - 评测

MolDiff模型是一种考虑分子键生成的3D分子生成的新模型。MolDiff是清华大学智能产业研究院马剑竹课题组发表在PMLR 2023的工作&#xff0c;第一作者是Xingang Peng&#xff0c;文章题目为&#xff1a;《 Addressing the Atom-Bond Inconsistency Problem in 3D Molecule Genera…

Rust中的链式调用方法

在Rust编程语言中&#xff0c;链式调用是一种流行的编程模式&#xff0c;它允许开发者以流畅、连续的方式调用多个方法。这种风格不仅提高了代码的可读性&#xff0c;而且使得复杂的操作可以串联在一起&#xff0c;形成一个清晰、简洁的语句。在Rust中&#xff0c;链式调用主要…

【Android】Kotlin学习之数据容器 -- 集合

一. 定义 List : 是一个有序列表, 可通过下标访问元素. 元素可以在list中出现多次, 元素可重复 Set : 是元素唯一的集合, 一般来说Set中元素的顺序并不重要, 无序集合. Map : 是一组键值对, 键是唯一的, 每个键刚好映射到一个值, 值可以重复 二. 集合创建 三. 示例 mutabl…