首页
/ STINGER图数据库JSON-RPC API详解

STINGER图数据库JSON-RPC API详解

2025-06-04 22:43:18作者:彭桢灵Jeremy

概述

STINGER图数据库提供了一套基于JSON-RPC 2.0规范的API接口,允许客户端应用程序查询图数据和算法计算结果。本文将全面解析这套API的功能和使用方法,帮助开发者快速掌握STINGER的远程调用能力。

JSON-RPC基础

STINGER实现的JSON-RPC 2.0接口具有以下特点:

  • 仅支持命名参数调用,不支持位置参数
  • 当前版本不支持通知(Notifications)功能
  • 当前版本不支持批量(Batch)请求
  • 响应中包含"millis"字段,表示服务器端执行时间(毫秒)

核心API方法详解

1. 服务器信息查询

get_server_info方法用于获取STINGER服务器基本信息:

请求示例:
{
  "jsonrpc": "2.0",
  "method": "get_server_info",
  "id": 1
}

响应示例:
{
  "jsonrpc": "2.0",
  "result": {
    "pid": 12345 
  },
  "id": 1,
  "millis": 0.5
}

2. 图统计信息

get_graph_stats方法返回图的整体统计信息:

请求示例(带类型信息):
{
  "jsonrpc": "2.0",
  "method": "get_graph_stats",
  "params": {
    "get_types": true
  },
  "id": 2
}

响应示例:
{
  "jsonrpc": "2.0",
  "result": {
    "vertices": 1000,
    "edges": 5000,
    "time": 1580000000,
    "edge_types": ["friendship", "collaboration"],
    "vertex_types": ["user", "product"]
  },
  "id": 2,
  "millis": 2.3
}

3. 算法管理

get_algorithms获取当前运行的算法列表:

响应示例:
{
  "jsonrpc": "2.0",
  "result": {
    "algorithms": ["pagerank", "community_detection"]
  },
  "id": 3,
  "millis": 1.2
}

get_data_description查询算法输出的数据字段:

请求示例:
{
  "jsonrpc": "2.0",
  "method": "get_data_description",
  "params": {
    "name": "pagerank"
  },
  "id": 4
}

响应示例:
{
  "jsonrpc": "2.0",
  "result": {
    "alg_data": ["score", "normalized_score"]
  },
  "id": 4,
  "millis": 1.8
}

数据查询方法

STINGER提供了多种数据查询方式,满足不同场景需求:

1. 全量数据获取

get_data_array获取算法输出的完整数据:

请求示例(带采样参数):
{
  "jsonrpc": "2.0",
  "method": "get_data_array",
  "params": {
    "name": "pagerank",
    "data": "score",
    "samples": 100,
    "log": true
  },
  "id": 5
}

2. 范围查询

get_data_array_rangeget_data_array_sorted_range支持分页和排序:

请求示例(排序分页):
{
  "jsonrpc": "2.0",
  "method": "get_data_array_sorted_range",
  "params": {
    "name": "pagerank",
    "data": "score",
    "offset": 0,
    "count": 10,
    "order": "DESC"
  },
  "id": 6
}

3. 定点查询

get_data_array_set查询指定顶点的数据:

请求示例:
{
  "jsonrpc": "2.0",
  "method": "get_data_array_set",
  "params": {
    "name": "pagerank",
    "data": "score",
    "set": [1001, 1002, "user_1003"]
  },
  "id": 7
}

4. 聚合计算

get_data_array_reduction支持数据聚合:

请求示例:
{
  "jsonrpc": "2.0",
  "method": "get_data_array_reduction",
  "params": {
    "name": "pagerank",
    "data": "score",
    "op": "sum"
  },
  "id": 8
}

实时图分析功能

STINGER提供了多种实时图算法API:

1. 广度优先搜索(BFS)

breadth_first_search查找最短路径:

请求示例:
{
  "jsonrpc": "2.0",
  "method": "breadth_first_search",
  "params": {
    "source": "user_123",
    "target": "user_456",
    "get_types": true
  },
  "id": 9
}

2. Adamic-Adar指数

adamic_adar_index计算顶点相似度:

请求示例:
{
  "jsonrpc": "2.0",
  "method": "adamic_adar_index",
  "params": {
    "source": "user_123",
    "include_neighbors": true
  },
  "id": 10
}

会话管理

STINGER支持会话式操作:

register创建新会话:

请求示例:
{
  "jsonrpc": "2.0",
  "method": "register",
  "params": {
    "type": "algorithm_monitor"
  },
  "id": 11
}

request使用会话查询数据:

请求示例:
{
  "jsonrpc": "2.0",
  "method": "request",
  "params": {
    "session_id": 12345
  },
  "id": 12
}

最佳实践建议

  1. 对于大型图数据,合理使用stride和samples参数控制返回数据量
  2. 优先使用定点查询而非全量查询,减少网络传输
  3. 长时间监控可使用会话机制,减少连接开销
  4. 注意API响应中的millis字段,监控查询性能

通过这套JSON-RPC API,开发者可以方便地将STINGER图数据库的强大分析能力集成到各类应用中。

登录后查看全文
热门项目推荐

热门内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
164
256
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
122
175
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
824
492
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
176
260
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
324
1.07 K
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
388
366
IssueSolutionDemosIssueSolutionDemos
用于管理和运行HarmonyOS Issue解决方案Demo集锦。
ArkTS
13
12
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.05 K
0
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
79
2
WxJavaWxJava
微信开发 Java SDK,支持微信支付、开放平台、公众号、视频号、企业微信、小程序等的后端开发,记得关注公众号及时接受版本更新信息,以及加入微信群进行深入讨论
Java
820
22