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

STINGER图数据库JSON-RPC API详解

2025-06-04 23:02:19作者:彭桢灵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图数据库的强大分析能力集成到各类应用中。

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

热门内容推荐

最新内容推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
895
531
KonadoKonado
Konado是一个对话创建工具,提供多种对话模板以及对话管理器,可以快速创建对话游戏,也可以嵌入各类游戏的对话场景
GDScript
21
13
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
85
4
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
372
387
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.09 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
94
15
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
625
60
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
401
377