dremio 学习七 开发arp 连接器

arp 是dremio 提供的一个高级关系下推框架,可以方便我们开发自定义的数据连接器

arp 开发流程

  • 结构 (比drill 开发方便多了) 
    存储插件配置 [data source]Conf,java 
    插件arp yaml 定义文件 [data source].arp.yaml
  • 说明 
    配置定义了,界面如何进行连接配置,以及数据驱动如何使用 
    arp yaml 文件,可以进行sql 查询的修改,可以进行不同数据类型、函数,以及重写

arp 文件格式

  • 包含的部分 
    主要包含以下几个部分 
    Metadata 高级元数据信息 
    Syntax 语法 
    Data types 定义了jdbc 驱动的数据类型以及如何与dremio 类型映射 
    Relational Algebra 包含以下部分 
    Aggregation 指定聚合算法,可以进行重写 
    excep/project/join/sort/union/unpin_all/values 自定操作的支持情况 
    exressions 概述操作的支持 
    operators 概述标量操作的支持,同时可以进行重写 
    variable_length_operators 定义标量支持的操作的数量,比如and、 or (算是逻辑操作)

参考模板

https://github.com/dremio-hub/dremio-sqllite-connector/blob/master/src/main/java/com/dremio/exec/store/jdbc/conf/SqliteConf.java

说明

dremio 的arp 开发是扩展数据连接一个很不错的选择,同时开发也不是很难, 实际中如果大家为了方便我们可以直接集成
maven-shade-plugin 方便jdbc 驱动依赖的集成,后边尝试写一个简单的驱动插件,同时如果注意观察,会发现有些开源的扩展
对于ui 部分使用了一个json 定义文件,这样编写插件就更简单了

参考资料

https://www.dremio.com/tutorials/how-to-create-an-arp-connector/
https://github.com/panoramichq/dremio-bigquery-connector
https://github.com/dremio-brock/dremio-dynamodb-connector

posted on   荣锋亮  阅读(224)  评论(0编辑  收藏  举报

编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2020-02-09 pgspider tds fdw sql server docker 镜像试用
2019-02-09 nginx unit nodejs 模块试用(续)

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示