spark mac本地调试至轻云

Last updated on January 17, 2025 am

🧙 Questions

在mac中调试至轻云

☄️ Ideas

前提

  • 安装java
  • 安装gradle
  • 安装pnpm
  • 安装isx
  • 开启mac远程登录
下载编译代码

至轻云项目: spark-yun

# 下载代码
isx clone
# 安装依赖
isx install
# 构建代码
isx package
启动项目

或者使用idea运行项目

# 清理项目缓存文件
isx clean
# 启动项目
isx backend
创建项目基础信息
standalone调试
  • 添加集群
  • 集群: standalone
  • 类型: standalone
    • 节点: localhost
    • Host: localhost
    • 默认安装spark
    • 用户名: ispong
    • 密码:
  • 节点检测
  • 节点安装
  • 查看本地启动的spark: http://localhost:8081
偷梁换柱
bash /Users/ispong/zhiqingyun-agent/bin/stop.sh
# 然后使用idea启动至轻云代理
创建作业

短时间任务sparksql

CREATE TEMPORARY VIEW from_table
USING org.apache.spark.sql.jdbc
OPTIONS (
    driver 'com.mysql.cj.jdbc.Driver',
    url 'jdbc:mysql://47.92.152.18:40004/isxcode_db',
    user 'root',
    password 'Zhiqingyun@isxcode',
    dbtable 'users'
);

select count(1) from from_table;

长时间任务sparksql

CREATE TEMPORARY VIEW to_table
USING org.apache.spark.sql.jdbc
OPTIONS (
    driver 'com.mysql.cj.jdbc.Driver',
    url 'jdbc:mysql://47.92.152.18:40004/isxcode_db',
    user 'root',
    password 'Zhiqingyun@isxcode',
    dbtable 'supplier'
);

select count(1) from to_table;
k8s调试

启动k8s服务

# 检测服务是否启动
kubectl cluster-info

# 拉取镜像
docker pull apache/spark:v3.1.3
# 创建zhiqingyun-space空间
kubectl create namespace zhiqingyun-space
# 创建账号zhiqingyun
kubectl create serviceaccount zhiqingyun -n zhiqingyun-space
# 构建权限spark-role
kubectl create clusterrolebinding spark-role --clusterrole=edit --serviceaccount=zhiqingyun-space:zhiqingyun --namespace=zhiqingyun-space
  • 添加集群
    • 集群: k8s
    • 类型: kubernetes
    • 节点: localhost
    • Host: localhost
    • 用户名: ispong
    • 密码:
  • 节点检测
  • 节点安装
偷梁换柱
bash /Users/ispong/zhiqingyun-agent/bin/stop.sh
# idea启动至流云代理
yarn调试

启动hadoop服务

start-all.sh
  • 查看yarn服务: http://ispong-mac.local:8088

  • 添加集群

    • 集群: yarn
    • 类型: yarn
    • 节点: localhost
    • Host: localhost
    • 用户名: ispong
    • 密码:
  • 节点检测

  • 节点安装

偷梁换柱
bash /Users/ispong/zhiliuyun-agent/bin/stop.sh
# idea启动至流云代理
调试代码
sparkLauncher.addAppArgs(Base64.getEncoder()
               .encodeToString(yagExecuteWorkReq.getPluginReq() == null ? yagExecuteWorkReq.getArgsStr().getBytes()
                   : JSON.toJSONString(yagExecuteWorkReq.getPluginReq()).getBytes()));
修改plugin

args = new String[]{"eyJhZ2VudFR5cGUiOiJzdGFuZGFsb25lIiwiY29udGFpbmVyUG9ydCI6MCwiY3N2RmlsZU5hbWUiOiJzeV8xODIyOTQ0MTI0OTE2MTk1MzI4LmNzdiIsImNzdkZpbGVQYXRoIjoiL1VzZXJzL2lzcG9uZy96aGlxaW5neXVuLWFnZW50L2ZpbGUvc3lfMTgyMjk0NDEyNDkxNjE5NTMyOC5jc3YiLCJleGNlbFN5bmNDb25maWciOnsiY29sdW1uTWFwIjpbeyJzb3VyY2UiOiJhY2NvdW50X2lkIiwidGFyZ2V0IjoidXNlcm5hbWUifV0sImZpbGVQYXR0ZXJuIjoiIiwiZmlsZVJlcGxhY2UiOmZhbHNlLCJoYXNIZWFkZXIiOnRydWUsIm92ZXJNb2RlIjoiT1ZFUldSSVRFIiwicXVlcnlDb25kaXRpb24iOiIiLCJzb3VyY2VGaWxlSWQiOiJzeV8xODIyOTQ0MTI0OTE2MTk1MzI4Iiwic291cmNlVGFibGVDb2x1bW4iOlt7ImNvZGUiOiJsb2d0aW1lIiwic3FsIjoiIiwidHlwZSI6IlN0cmluZyJ9LHsiY29kZSI6ImFjY291bnRfaWQiLCJzcWwiOiIiLCJ0eXBlIjoiU3RyaW5nIn0seyJjb2RlIjoiaXAiLCJzcWwiOiIiLCJ0eXBlIjoiU3RyaW5nIn1dLCJ0YXJnZXREQklkIjoic3lfMTgxODEzMDYxNzk2NDA0MDE5MiIsInRhcmdldERCVHlwZSI6IkhJVkUiLCJ0YXJnZXREYXRhYmFzZSI6eyJkYlRhYmxlIjoidXNlcnMiLCJkcml2ZXIiOiJvcmcuYXBhY2hlLmhpdmUuamRiYy5IaXZlRHJpdmVyIiwidXJsIjoiamRiYzpoaXZlMjovLzguMTQyLjE0NC4xMDA6MzAxMTUvaXNwb25nX2RiIiwidXNlciI6ImRlaG9vcCJ9LCJ0YXJnZXRUYWJsZSI6InVzZXJzIiwidGFyZ2V0VGFibGVDb2x1bW4iOlt7ImNvZGUiOiJ1c2VybmFtZSIsInR5cGUiOiJTVFJJTkcifSx7ImNvZGUiOiJhZ2UiLCJ0eXBlIjoiSU5UIn1dLCJ3b3JrSWQiOiJzeV8xODIyODU5MzI2NDQwODUzNTA0In0sImZ1bmNJbmZvTGlzdCI6W10sInNwYXJrQ29uZmlnIjp7InNwYXJrLmV4ZWN1dG9yLm1lbW9yeSI6IjJnIiwic3Bhcmsuc3FsLnBhcnF1ZXQud3JpdGVMZWdhY3lGb3JtYXQiOiJ0cnVlIiwic3BhcmsuZHJpdmVyLm1lbW9yeSI6IjFnIiwic3Bhcmsuc3FsLnBhcnF1ZXQuZGF0ZXRpbWVSZWJhc2VNb2RlSW5Xcml0ZSI6IkxFR0FDWSIsInNwYXJrLmRyaXZlci5jb3JlcyI6IjEiLCJzcGFyay5zcWwuc3RvcmVBc3NpZ25tZW50UG9saWN5IjoiTEVHQUNZIiwic3BhcmsuZXhlY3V0b3IuY29yZXMiOiIxIiwic3Bhcmsuc3FsLnBhcnF1ZXQuaW50OTZSZWJhc2VNb2RlSW5SZWFkIjoiTEVHQUNZIiwic3Bhcmsuc3FsLnBhcnF1ZXQuZGF0ZXRpbWVSZWJhc2VNb2RlSW5SZWFkIjoiTEVHQUNZIiwic3Bhcmsuc3FsLmxlZ2FjeS50aW1lUGFyc2VyUG9saWN5IjoiTEVHQUNZIiwic3Bhcmsuc3FsLnBhcnF1ZXQuaW50OTZSZWJhc2VNb2RlSW5Xcml0ZSI6IkxFR0FDWSIsInNwYXJrLnNxbC5hdXRvQnJvYWRjYXN0Sm9pblRocmVzaG9sZCI6Ii0xIiwic3BhcmsuZXhlY3V0b3IuaW5zdGFuY2VzIjoiMSIsInNwYXJrLmV4ZWN1dG9yLmV4dHJhSmF2YU9wdGlvbnMiOiItRGZpbGUuZW5jb2Rpbmc9dXRmLTgiLCJzcGFyay5jb3Jlcy5tYXgiOiIxIiwic3BhcmsuZHJpdmVyLmV4dHJhSmF2YU9wdGlvbnMiOiItRGZpbGUuZW5jb2Rpbmc9dXRmLTgiLCJzcGFyay5zcWwucGFycXVldC5lbmFibGVWZWN0b3JpemVkUmVhZGVyIjoiZmFsc2UifSwic3luY1J1bGUiOnsibnVtQ29uY3VycmVuY3kiOjEsIm51bVBhcnRpdGlvbnMiOjEsInNldE1vZGUiOiJTSU1QTEUiLCJzcWxDb25maWdKc29uIjoibnVsbCJ9fQ=="};
ï
    public static SparkConf initSparkConf(Map<String, String> sparkConfig) {
        SparkConf conf = new SparkConf();
//        if (sparkConfig != null) {
//            for (Map.Entry<String, String> entry : sparkConfig.entrySet()) {
//                conf.set(entry.getKey(), entry.getValue());
//            }
//        }
        conf.set("spark.master", "local[*]");
        return conf;
    }

spark mac本地调试至轻云
https://ispong.isxcode.com/hadoop/spark/spark mac本地调试至轻云/
Author
ispong
Posted on
April 22, 2024
Licensed under