Drasi Sources SDK
什么是Drasi数据源(Source)?
Source提供了与系统的连接,Drasi 可以将这些系统视为变化源。source 在 Drasi 中执行三个重要功能:
- 处理源系统生成的更改日志/源,并将这些更改推送到使用该源作为输入的每个连续查询。
- 将源更改数据转换为一致的属性图数据模型,以便订阅的 Continuous Queries 可以使用该数据,就像使用 Nodes 和 Relations 的图形一样。对于图形源(如 Gremlin),无需转换。但对于非图形源,例如 PostgreSQL 和 Kubernetes,Source 会转换数据(更多详细信息在各个 Sources 部分中提供)。
- 为 Continuous Queries 提供一种方法,以便在启动时查询源系统以初始化 Continuous Query 结果的状态。
Drasi Sources SDK 是一个用于实现 Drasi 数据源的多语言开发工具包,目前支持 Java、.NET、Rust 等编程语言。这个 SDK 的主要目的是帮助开发者创建和管理 Drasi 平台的数据源。扩展Drasi Sources的文档参见 https://github.com/drasi-project/docs/blob/main/docs/content/how-to-guides/extend-drasi/implement-a-source.md
每个数据源由两个核心部分组成:
两个主要组件:
a) Source Reactivator(数据源响应器):负责监控和处理数据变化
- 监听源数据存储的变更流
- 将数据转换为图结构
- 将变更推送到持续查询系统
- 支持状态存储,用于保存游标等信息
b) Source Proxy(数据源代理):负责初始数据的获取和加载 :
- 处理新的持续查询的初始化
- 通过查询数据存储获取初始状态
- 将数据转换为图结构
支持的数据操作:
- 节点(Node)的创建和管理
- 关系(Relation)的创建和管理
- 属性(Properties)的管理
- 变更事件的处理
- 控制事件的处理
- 特点和优势
- 多语言支持:提供 Java、.NET、Rust 等多种语言的实现
- 异步处理:支持异步流式处理数据变更
- 状态管理:提供状态存储功能,支持游标管理
- 配置灵活:支持自定义配置属性
- 容器化部署:支持容器化部署和管理
- 事件驱动:基于事件驱动架构处理数据变更
SDK 的设计理念是提供一个统一的接口来实现各种数据源的接入,同时保持足够的灵活性以适应不同的使用场景。无论是简单的数据源还是复杂的数据处理系统,都可以通过这个 SDK 来实现与 Drasi 平台的集成。
实现自定义数据源的步骤
第一步:实现Source Proxy(数据源代理)
Source Proxy主要负责在查询部署时获取初始数据。它需要提供一个HTTP服务器,并实现/acquire接口来处理初始数据的加载。
using System.Runtime.CompilerServices;
using System.Text.Json.Nodes;
using Drasi.Source.SDK;
using Drasi.Source.SDK.Models;
using Microsoft.Extensions.Configuration;
var proxy = new SourceProxyBuilder()
.UseBootstrapHandler<BootstrapHandler>()
.Build();
await proxy.StartAsync();
class BootstrapHandler : IBootstrapHandler
{
public BootstrapHandler(IConfiguration configuration)
{
Console.WriteLine($"Connection string: {configuration["connectionString"]}");
}
public async IAsyncEnumerable<SourceElement> Bootstrap(BootstrapRequest request, [EnumeratorCancellation]CancellationToken cancellationToken = default)
{
if (request.NodeLabels.Contains("Person"))
{
yield return new SourceElement("person-1", ["Person"], new JsonObject
{
{ "name", "Alice" },
{ "age", 30 }
});
yield return new SourceElement("person-2", ["Person"], new JsonObject
{
{ "name", "Bob" },
{ "age", 40 }
});
}
if (request.RelationLabels.Contains("Knows"))
{
yield return new SourceElement("1-2", ["Knows"], new JsonObject
{
{ "since", 2010 }
}, "person-1", "person-2");
}
}
}
数据模型
SourceElement 类
- 支持节点和关系数据
- JSON 属性支持
- 标签系统
第二步:实现Source Reactivator(数据源响应器)
Source Reactivator负责监控数据变化并通过Dapr的pub/sub(发布/订阅)功能将变化事件发送给其他组件。
数据变化事件格式
所有的数据变化事件都需要包含三个必须字段:
op:操作类型payload:数据负载ts_ms:时间戳(毫秒)
1. 新增数据事件格式
{
"op": "i", // i 表示 insert(插入)
"payload": {
"after": {
"id": "001",
"labels": ["用户", "VIP"],
"properties": {
"name": "张三",
"age": 30
}
},
"before": {}, // 新增时before为空
"source": {
"table": "node", // node表示节点,relation表示关系
"ts_ms": "1676908799000"
}
},
"ts_ms": 1676908799000
}
2. 更新数据事件格式
{
"op": "u", // u 表示 update(更新)
"payload": {
"after": {
"id": "001",
"labels": ["用户", "VIP"],
"properties": {
"name": "张三",
"age": 31
}
},
"before": {
"id": "001",
"labels": ["用户", "VIP"],
"properties": {
"name": "张三",
"age": 30
}
},
"source": {
"table": "node",
"ts_ms": "1676908799000"
}
},
"ts_ms": 1676908799000
}
3. 删除数据事件格式
{
"op": "d", // d 表示 delete(删除)
"payload": {
"after": {}, // 删除时after为空
"before": {
"id": "001",
"labels": ["用户", "VIP"],
"properties": {
"name": "张三",
"age": 31
}
},
"source": {
"table": "node",
"ts_ms": "1676908799000"
}
},
"ts_ms": 1676908799000
}
注册你的数据源
创建SourceProvider配置
要注册新的数据源类型,你需要创建一个SourceProvider配置文件。这个配置描述了数据源的组件和配置选项。
apiVersion: v1
kind: SourceProvider
name: MySource
spec:
services:
proxy:
image: my-proxy
externalImage: true
dapr:
app-port: "80"
reactivator:
image: my-reactivator
externalImage: true
deprovisionHandler: true
dapr:
app-port: "80"
config_schema:
type: object
properties:
connectionString: # sample config property
type: string
使用数据源
创建Source配置文件来使用已注册的数据源:
apiVersion: v1
kind: Source
name: test-source
spec:
kind: MySource
properties:
connectionString: "my-connection-string"
部署和管理命令
# 注册数据源提供者
drasi apply -f source-provider.yaml
# 查看所有可用的数据源类型
drasi list sourceprovider
# 部署具体的数据源实例
drasi apply -f source.yaml
调试和验证
配置文件验证:
- 使用Drasi CLI:
drasi apply --dry-run -f your-source.yaml - 使用VSCode插件:安装Drasi VSCode扩展,可以自动验证配置文件
- 使用Drasi CLI:
常见问题排查:
- 确保Docker镜像已正确推送到镜像仓库
- 检查服务端口配置是否正确
- 验证数据库连接信息
- 查看容器日志排查问题
最佳实践:
- 在开发环境中充分测试
- 使用环境变量管理敏感信息
- 实现健康检查接口
- 添加详细的日志记录
常见问题
Q: 如何确保数据源的安全性? A: 使用环境变量存储敏感信息,启用SSL连接,实施适当的访问控制。
Q: 数据源支持哪些类型的数据变化监控? A: 支持新增(insert)、更新(update)和删除(delete)三种基本操作的监控。
Q: 如何处理大量数据的初始加载? A: 考虑使用分页加载,实现断点续传,或者使用批量处理机制。
Drasi Sources SDK的更多相关文章
- [原]Android开发环境搭建
[Date]2014-04-20 [Author]wintys (wintys@gmail.com) http://wintys.cnblogs.com [Keywords]android . 离线a ...
- android 55
智能家居:可以联网可以用指令操作可以返回状态.智能微波炉智能眼镜智能手表. Android作者Andy Rubin,2007年正式由谷歌推广,开源的. 安卓体系结构和开发一个闹钟的调用结构图: 安卓和 ...
- jenkins集成sonar
用于我的sonar已经在一台机器上搭建好了,但是每次都要人工去执行sonar-run,很麻烦,所以就想着集成到jenkins上,在jenkins上点点按钮就可以看sonar结果,所以很抱歉,本博客不设 ...
- 在Ubuntu环境下搭建esp32开发环境
第一步:下载必要的库文件 sudo apt-get install git make gcc libncurses5-dev flex bison gperf python-serial ...
- Android SDK 在线更新镜像服务器资源
本文转自:http://blog.kuoruan.com/24.html.感谢原作者. 什么是Android SDK SDK:(software development kit)软件开发工具包.被软件 ...
- Android开发加快sdk更新速度
1.在:\Windows\System32\drivers\etc目录下找到host文件,不能再这个目录修改host文件,需要先拷贝到桌面 然后把一下地址添加到host文件的最末尾 203.208.4 ...
- 搭建Android开发环境附图详解+模拟器安装(JDK+Eclipse+SDK+ADT)
——搭建android开发环境的方式有多种,比如:JDK+Eclipse+SDK+ADT或者JDK+Eclipse+捆绑好的AndroidSDK或者Android Studio. Google 决定将 ...
- Android SDK Manager 更新代理配置
转自:http://www.cnblogs.com/tao560532/p/4483067.html 出现问题: 消除SDK更新时,有可能会出现这样的错误:Download interrupted: ...
- Eclipse更新SDK速度慢,解决办法
在SDK Manager -> tools -> options中: HTTP Proxy Server: mirrors.neusoft.edu.cn HTTP Proxy Port: ...
- 在Linux上编译dotnet cli的源代码生成.NET Core SDK的安装包
.NET 的开源,有了更多的DIY乐趣.这篇博文记录一下在新安装的 Linux Ubuntu 14.04 上通过自己动手编译 dotnet cli 的源代码生成 .net core sdk 的 deb ...
随机推荐
- idea springboot 微服务批量启动
概要 在使用IDEA开发微服务的时候,微服务比较多,启动起来比较麻烦,下面介绍一下使用批量启动微服务的方法. 方法 编辑当前项目根目录下的 .idea\workspace.xml 文件. 找到 < ...
- Echarts 颜色管理
1.Echarts的颜色设计 Echarts的颜色的设置分为两种:色盘和具体颜色 色盘适合做全局设置,因为他里面有多个颜色,通俗的说色盘就是颜色预设值列表,色盘统一使用color属性进行配置. 而具体 ...
- 基于 C# 编写的 Visual Studio 文件编码显示与修改扩展插件
前言 在软件开发过程中,尤其是在处理跨平台或来自不同来源的项目时,文件的编码格式往往会成为一个不可忽视的问题.不同的操作系统.编程语言和编辑器可能对文件编码有不同的支持和默认设置,这可能导致在打开一个 ...
- GienTech动态|入选软件和信息技术服务竞争力百强;参展世界计算大会、网络安全博览会
---- GienTech动态 ---- 中电金信参展广东省网络安全博览会.世界计算机大会 近期,中电金信跟随中国电子参展2023年广东省网络安全博览会(下简称"博览会&qu ...
- [MySQL]数据库修复(Example:1146 Error )
删除数据库自带的表,导致的异常问题修复方法如下 运行cmd,查询MYSQL所在位置 where mysql cd到MySQL安装目录的bin目录下 执行命令 mysql_upgrade -u root ...
- 【Linux】【虚拟机】 IP地址的动态与静态设置
目录 配置文件的修改 配置文件的修改 vim /etc/sysconfig/network-scripts/ifcfg-ens33 IP配置方式(不指定:none,静态:static,动态:dhcp) ...
- 4.4 服务器上的 Git - 配置服务器
配置服务器 我们来看看如何配置服务器端的 SSH 访问. 本例中,我们将使用 authorized_keys 方法来对用户进行认证. 同时我们假设你使用的操作系统是标准的 Linux 发行版,比如 U ...
- Collector的配置和使用
目录 Collector的配置和使用 Collector配置 Receivers Processors Exporters Service Extensions 使用环境变量 Collector的使用 ...
- Redis 中 scan 命令踩坑
原本以为自己对redis命令还蛮熟悉的,各种数据模型各种基于redis的骚操作.但是最近在使用redis的scan的命令式却踩了一个坑,顿时发觉自己原来对redis的游标理解的很有限.所以记录下这个踩 ...
- Navicat Premium15安装与激活
Navicat premium是一款数据库管理工具,是一个可多重连线资料库的管理工具,它可以让你以单一程式同时连线到 MySQL.SQLite.Oracle 及 PostgreSQL 资料库,让管理不 ...