Hue兼容Livy通过Rest请求向Spark发送任务
参考hue官方文档
https://gethue.com/how-to-use-the-livy-spark-rest-job-server-for-interactive-spark-2-2/
AI 代码解读
环境准备
必须安装JDK
必须安装HADOOP
必须安装Spark
安装过程
下载
wget http://archive.cloudera.com/beta/livy/livy-server-0.3.0.zip
AI 代码解读
解压
unzip ./livy-server-0.3.0.zip
AI 代码解读
修改conf/livy.conf
#默认local模式
#增加如下配置
livy.server.session.factory = yarn
AI 代码解读
修改conf/livy-env.sh
#增加如下配置
export SPARK_HOME=/opt/spark
export HADOOP_CONF_DIR=/etc/hadoop/conf
export SPARK_CONF_DIR=/opt/spark/conf
AI 代码解读
启动livy-server服务
#写上start是后台运行
bin/livy-server start
AI 代码解读
查看服务进程
jps 20229 LivyServer
AI 代码解读
Hue兼容
修改hue.ini
#添加如下内容
[spark]
# livy 服务器域名
livy_server_host=ddc001.lqad
# livy 服务器端口
livy_server_port=8998
# Configure Livy to start in local 'process' mode, or 'yarn' workers.
livy_server_session_kind=yarn
AI 代码解读
使用样例
引入第三方依赖
import util.Random
val r = new Random
println(r.nextInt(10))
AI 代码解读
运行结果
创建spark任务
var counter = 0
val data = Array(1, 2, 3, 4, 5)
var rdd = sc.parallelize(data)
rdd.map(x=>x+1).collect()
AI 代码解读