前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >基于SparkSQL实现的一套即席查询服务

基于SparkSQL实现的一套即席查询服务

作者头像
UFO
发布2018-12-28 12:19:28
2K0
发布2018-12-28 12:19:28
举报
文章被收录于专栏:Spark生态圈Spark生态圈

IQL (项目地址:https://github.com/teeyog/IQL)

README-EN

基于SparkSQL实现了一套即席查询服务,具有如下特性:

  • 优雅的交互方式,支持多种datasource/sink,多数据源混算
  • spark常驻服务,基于zookeeper的引擎自动发现
  • 负载均衡,多个引擎随机执行
  • 多session模式实现并行查询
  • 采用spark的FAIR调度,避免资源被大任务独占
  • 基于spark的动态资源分配,在无任务的情况下不会占用executor资源
  • 支持Cluster和Client模式启动
  • 基于Structured Streaming实现SQL动态添加流
  • 类似SparkShell交互式数据分析功能
  • 高效的script管理,配合import/include语法完成各script的关联
  • 对数据源操作的权限验证

支持的数据源:hdfs、hive、hbase、kafka、mysql、es、mongo

支持的文件格式:parquet、csv、orc、json、text、xml

在Structured Streaming支持的Sink之外还增加了对Hbase、MySQL、es的支持

Quickstart

HBase

加载数据
代码语言:javascript
复制
load hbase.t_mbl_user_version_info 
where `spark.table.schema`="userid:String,osversion:String,toolversion:String"
       and `hbase.table.schema`=":rowkey,info:osversion,info:toolversion" 
       and `hbase.zookeeper.quorum`="localhost:2181"
as tb;

参数

说明

默认值

hbase.zookeeper.quorum

zookeeper地址

localhost:2181

spark.table.schema

Spark临时表对应的schema(eg: "ID:String,appname:String,age:Int")

hbase.table.schema

HBase表对应schema(eg: ":rowkey,info:appname,info:age")

spark.rowkey.view.name

rowkey对应的dataframe创建的temp view名 ,设置了该值后只获取rowkey对应的数据

可获取指定rowkey集合对应的数据,spark.rowkey.view.name 即是rowkey集合对应的tempview,默认获取第一列为rowkey列

保存数据
代码语言:javascript
复制
save tb1 as hbase.tableName 
where `hbase.zookeeper.quorum`="localhost:2181"
      and `hbase.table.rowkey.filed`="name"

参数

说明

默认值

hbase.zookeeper.quorum

zookeeper地址

localhost:2181

hbase.table.rowkey.field

spark临时表中作为hbase的rowkey的字段名

第一个字段

bulkload.enable

是否启动bulkload

false

hbase.table.name

Hbase表名

hbase.table.family

列族名

info

hbase.table.region.splits

预分区方式1:直接指定预分区分区段,以数组字符串方式指定,如 ['1','2','3']

hbase.table.rowkey.prefix

预分区方式2:当rowkey是数字,预分区只需指定前缀的formate形式,如 00 即可生成00-99等100个分区

hbase.table.startKey

预分区开始key

hbase.table.endKey

预分区结束key

hbase.table.numReg

分区个数

hbase.check_table

写入hbase表时,是否需要检查表是否存在

false

hbase.cf.ttl

ttl

MySQL

  • 加载数据
代码语言:javascript
复制
load jdbc.ai_log_count 
where driver="com.mysql.jdbc.Driver" 
      and url="jdbc:mysql://localhost/db?characterEncoding=utf8" 
      and user="root" 
      and password="***" 
as tb; 
  • 保存数据
代码语言:javascript
复制
save append tb as jdbc.aatest_delete;

文件操作 (其中formate可为:json、orc、csv、parquet、text)

  • 加载数据
代码语言:javascript
复制
load format.`path` as tb;
  • 保存数据
代码语言:javascript
复制
save tb as formate.`path` partitionBy uid coalesce 2;

Kafka

  • 离线
代码语言:javascript
复制
load kafka.`topicName`
where maxRatePerPartition="200"
   and `group.id`="consumerGroupId"
as tb;
select * from tb;

参数

说明

默认值

autoCommitOffset

是否提交offset

false

  • 实时
代码语言:javascript
复制
load kafka.`mc-monitor` 
where startingoffsets="latest"
    and failOnDataLoss="false"
    and `spark.job.mode`="stream" 
as tb1;

register watermark.tb1
where eventTimeCol="timestamp"
and delayThreshold="10 seconds"

select window.end as time_end,
count(1) as count
from tb1 a  
group by  window(a.timestamp,"10 seconds","10 seconds")
as tb2;

save tb2 as json.`/tmp/abc6` 
where outputMode="Append"
    and streamName="Stream"
    and duration="10"
    and sendDingDingOnTerminated="true"
    and `mail.receiver`="3146635263@qq.com"
    and checkpointLocation="/tmp/cp/cp16";

参数

说明

默认值

spark.job.mode

任务模式(batch:离线任务,stream:实时任务)

batch

mail.receiver

任务失败邮件通知(多个邮箱逗号分隔)

sendDingDingOnTerminated

钉钉Robot通知

false

实时任务失败会自动重启,可以通过streamJobMaxAttempts配置(默认3次)。

动态注册UDF函数

代码语言:javascript
复制
register udf.`myupper`
where func="
    def apply(name:String)={
        name.toUpperCase
    }
";

load jsonStr.'
{"name":"ufo"}
{"name":"uu"}
{"name":"HIN"}
' as tb1;

select myupper(name) as newName from tb1;

include(import等效)语法,通过路径引入脚本片段

import语法

参考

StreamingPro之MLSQL

spark sql在喜马拉雅的使用之xql

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.12.24 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • IQL (项目地址:https://github.com/teeyog/IQL)
  • Quickstart
    • HBase
      • 加载数据
      • 保存数据
    • MySQL
      • 文件操作 (其中formate可为:json、orc、csv、parquet、text)
        • Kafka
          • 动态注册UDF函数
            • include(import等效)语法,通过路径引入脚本片段
              • 参考
              相关产品与服务
              云数据库 MySQL
              腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档