4.3.图操作

4.3.1.图数据

4.3.1.1.创建图

功能介绍

创建一个新图,该操作需要图空间管理员或者超级管理员权限

URI
POST /graphspaces/${graphspace}/graphs/${graph}
URI参数
名称 是否必填 类型 默认值 取值范围 说明
graphspace String 图空间
graph String
Body参数
名称 是否必填 类型 默认值 取值范围 说明
backend String 存储类型,目前仅支持hstore
serializer String 序列化类型,目前仅支持binary
store String 与图名保持一致
rate_limit.write Integer 0 [0, Integer.MAX_VALUE) 每秒写入/更新/删除的请求数上限,0表示不限制
rate_limit.read Integer 0 [0, Integer.MAX_VALUE) 每秒读请求数上限,0表示不限制
task.wait_timeout Long 10L [0, Long.MAX_VALUE) 异步任务的等待时间
task.input_size_limit Integer 1010241024 [0, 102410241024) 任务的输入大小限制,单位字节
task.result_size_limit Integer 1010241024 [0, 102410241024) 任务的结果大小限制,单位字节
task.scheduler_type String local [local, etcd] 使用何种调度器进行异步任务调度,默认为local。 调度器类型不可修改
vertex.check_customized_id_exist Boolean false 是否检查指定的顶点或边的ID是否存在
vertex.tx_capacity Integer 10000 [500, 1000000) 事务里未提交的顶点数目限制
edge.tx_capacity Integer 10000 [500, 1000000) 事务里未提交的边数目限制
schema.init_template String 创建图时用来初始化的元数据模板
schema.illegal_name_regex String ".*\s+$ ~.*" 非法的元数据名字的正则表达式
schema.cache_capacity Long 10000 [0, Long.MAX_VALUE) 元数据缓存数目上限
vertex.cache_capacity Long 1010001000L [0, Long.MAX_VALUE) 顶点缓存数目上限
vertex.cache_expire Integer 600 [0, Integer.MAX_VALUE) 顶点在缓存中过期的期限
edge.cache_capacity Long 1000*1000L [0, Long.MAX_VALUE) 边缓存数目上限
edge.cache_expire Integer 600 [0, Integer.MAX_VALUE) 边在缓存中过期的期限
search.text_analyzer String jieba [word, ansj, hanlp, smartcn, jieba, jcseg, mmseg4j, ikanalyzer]
search.text_analyzer_mode String INDEX 不同的分词器对应的模式参加表格下方说明 分词器工作模式
graph.virtual_graph_enable Boolean false 是否启用虚拟图
graph.virtual_graph_batch_buffer_size Integer 0 [0, 65535) 虚拟图攒批加载buffer大小,默认为0即关闭攒批加载,攒批加载在并发很高时对吞吐有益处,但对延迟有伤害
graph.virtual_graph_batch_size Integer 50 [0, 65535) 虚拟图攒批加载每批次的大小
graph.virtual_graph_batch_time_ms Integer 100 [0, Integer.MAX_VALUE) 虚拟图攒批加载定时周期(单位:毫秒)
graph.virtual_graph_vertex_init_capacity Integer 1000 * 1000 [0, Integer.MAX_VALUE) 虚拟图缓存点的最小数量
graph.virtual_graph_vertex_max_size Long 100 1000 1000 [0, Long.MAX_VALUE) 虚拟图缓存点的最大数量
graph.virtual_graph_vertex_expire Long 60 * 100 [0, Long.MAX_VALUE) 虚拟图缓存点的过期时间(单位:秒)
graph.virtual_graph_edge_init_capacity Integer 10000 [0, Integer.MAX_VALUE) 虚拟图缓存边的最小数量
graph.virtual_graph_edge_max_size Long 1000 * 1000 [0, Long.MAX_VALUE) 虚拟图缓存边的最大数量
graph.virtual_graph_edge_expire Long 60 * 100 [0, Long.MAX_VALUE) 虚拟图缓存边的过期时间(单位:秒)
graph.virtual_graph_batcher_task_threads Integer Math.max(4, CPUS / 2) [1, Math.max(4, CPUS * 2)] 虚拟图攒批加载的线程数
search.text_analyzer search.text_analyzer_mode
word [MaximumMatching, ReverseMaximumMatching, MinimumMatching, ReverseMinimumMatching, BidirectionalMaximumMatching, BidirectionalMinimumMatching, BidirectionalMaximumMinimumMatching, FullSegmentation, MinimalWordCount, MaxNgramScore, PureEnglish]
ansj [BaseAnalysis, IndexAnalysis, ToAnalysis, NlpAnalysis]
hanlp [standard, nlp, index, nShort, shortest, speed]
smartcn []
jieba [SEARCH, INDEX]
jcseg [Simple, Complex]
mmseg4j [Simple, Complex, MaxWord]
ikanalyzer [smart, max_word]

##### Response

|  名称   | 类型  |  说明  |
|  ----  | ----  | ----  |
| name  | String |  图名 |
| backend  | String |  存储类型 |
| description  | String |  描述 |

##### 使用示例

###### Method & Url

POST http://localhost:8080/graphspaces/gs1/graphs/hugegraph


###### Request Body

```json
{
  "backend": "hstore",
  "serializer": "binary",
  "store": "hugegraph",
  "search.text_analyzer": "jieba",
  "search.text_analyzer_mode": "INDEX"
}
Response Status
201
Response Body
{
  "name": "hugegraph",
  "backend": "hstore",
  "description": ""
}

4.3.1.2.列出图空间中全部的图

功能介绍

列出图空间下中全部的图

URI
GET /graphspaces/${graphspace}/graphs
URI参数
名称 是否必填 类型 默认值 取值范围 说明
graphspace String 图空间
Body参数

Response
名称 类型 说明
graphs Array 图列表
使用示例
Method & Url
GET http://localhost:8080/graphspaces/gs1/graphs
Request Body

Response Status
200
Response Body
{
    "graphs": [
        "hugegraph",
        "hg1"
    ]
}

4.3.1.3.查看某个图的信息

功能介绍

查看图空间下某个图的信息

URI
GET /graphspaces/${graphspace}/graphs/${graph}
URI参数
名称 是否必填 类型 默认值 取值范围 说明
graphspace String 图空间
graph String
Body参数

Response
名称 类型 说明
name String 图名
backend String 存储类型
description String 描述
使用示例
Method & Url
GET http://localhost:8080/graphspaces/gs1/graphs/hugegraph
Request Body

Response Status
200
Response Body
{
  "name": "hugegraph",
  "backend": "hstore",
  "description": ""
}

4.3.1.4.清空图数据,包括schema、vertex、edge和index等

功能介绍

清空某个图的全部数据,包括schema、vertex、edge和index等,该操作需要图空间管理员或者超级管理员权限

URI
PUT /graphspaces/${graphspace}/graphs/${graph}
URI参数
名称 是否必填 类型 默认值 取值范围 说明
graphspace String 图空间
graph String
Body参数
名称 是否必填 类型 默认值 取值范围 说明
action String clear 动作
clear_schema Boolean 其中 clear_schema 为 true 时,不仅删除图数据(顶点和边),同时删除元数据(schema);clear_schema 为 false 时,只删除图数据(顶点和边),保留元数据(schema)
Response

使用示例
Method & Url
PUT http://localhost:8080/graphspaces/gs1/graphs/hugegraph
Request Body
{
  "action": "clear",
  "clear_schema": true
}
Response Status
200
Response Body

4.3.1.5.删除图

功能介绍

删除某个图,该操作需要图空间管理员权限或者超级管理员权限

URI
DELETE /graphspaces/${graphspace}/graphs/${graph}
URI参数
名称 是否必填 类型 默认值 取值范围 说明
graphspace String 图空间
graph String
Body参数

Response

使用示例
Method & Url
DELETE http://localhost:8080/graphspaces/gs1/graphs/hugegraph
Request Body

Response Status
204
Response Body

4.3.2 图配置

4.3.2.1.查看图的配置

功能介绍

查看某个图的配置,该操作需要管理员权限

URI
GET /graphspaces/${graphspace}/graphs/${graph}/conf
URI参数
名称 是否必填 类型 默认值 取值范围 说明
graphspace String 图空间
graph String
Body参数

Response
名称 类型 说明
search.text_analyzer String
search.text_analyzer_mode String
gremlin.graph String
serializer String
backend String 后端存储
store String 图名
pd.peers String pd地址
使用示例
Method & Url
GET http://localhost:8080/graphspaces/gs1/graphs/hugegraph/conf
Request Body

Response Status
200
Response Body
{
  "search.text_analyzer": "jieba",
  "gremlin.graph": "com.baidu.hugegraph.HugeFactory",
  "search.text_analyzer_mode": "INDEX",
  "serializer": "binary",
  "backend": "hstore",
  "store": "hugegraph1",
  "pd.peers": "127.0.0.1:8686"
}

4.3.3.图模式

合法的图模式包括:NONE,RESTORING,MERGING,LOADING

  • None 模式(默认),元数据和图数据的写入属于正常状态。特别的:
    • 元数据(schema)创建时不允许指定 ID
    • 图数据(vertex)在 id strategy 为 Automatic 时,不允许指定 ID
  • LOADING:批量导入数据时自动启用,特别的:
    • 添加顶点/边时,不会检查必填属性是否传入

Restore 时存在两种不同的模式: Restoring 和 Merging

  • Restoring 模式,恢复到一个新图中,特别的:
    • 元数据(schema)创建时允许指定 ID
    • 图数据(vertex)在 id strategy 为 Automatic 时,允许指定 ID
  • Merging 模式,合并到一个已存在元数据和图数据的图中,特别的:
    • 元数据(schema)创建时不允许指定 ID
    • 图数据(vertex)在 id strategy 为 Automatic 时,允许指定 ID

正常情况下,图模式为 None,当需要 Restore 图时,需要根据需要临时修改图模式为 Restoring 模式或者 Merging 模式,并在完成 Restore 时,恢复图模式为 None。

4.3.3.1 查看图模式

功能介绍

查看某个图的模式

URI
GET /graphspaces/${graphspace}/graphs/${graph}/mode
URI参数
名称 是否必填 类型 默认值 取值范围 说明
graphspace String 图空间
graph String
Body参数

Response
名称 类型 说明
mode String 图模式
使用示例
Method & Url
GET http://localhost:8080/graphspaces/gs1/graphs/hugegraph/mode
Request Body

Response Status
200
Response Body
{
    "mode": "NONE"
}

合法的图模式包括:NONE,RESTORING,MERGING

4.3.3.2.设置图模式

功能介绍

设置某个图的模式

URI
PUT /graphspaces/${graphspace}/graphs/${graph}/mode
URI参数
名称 是否必填 类型 默认值 取值范围 说明
graphspace String 图空间
graph String
Body参数
名称 是否必填 类型 默认值 取值范围 说明
NONE 或者 RESTORING 或者 MERGING String 模式
Response
名称 类型 说明
mode String 图模式
使用示例
Method & Url
PUT http://localhost:8080/graphspaces/gs1/graphs/hugegraph/mode
Request Body
"RESTORING"

合法的图模式包括:NONE,RESTORING,MERGING

Response Status
200
Response Body
{
    "mode": "RESTORING"
}

4.3.4.图的读模式(Graph Read Mode)

合法的图的读模式包括:OLTP_ONLY, ALL

  • OLTP 模式(默认),图的查询结果只包含OLTP类型的属性,不包含OLAP属性
  • ALL 模式,图的查询结果既包含OLTP类型的属性,又包含OLAP属性(如果有)

4.3.4.1.查看图的读模式

功能介绍

查看图的读模式

URI
GET /graphspaces/${graphspace}/graphs/${graph}/graph_read_mode
URI参数
名称 是否必填 类型 默认值 取值范围 说明
graphspace String 图空间
graph String
Body参数

Response
名称 类型 说明
graph_read_mode String 图模式
使用示例
Method & Url
GET http://localhost:8080/graphspaces/gs1/graphs/hugegraph/graph_read_mode
Request Body

Response Status
200
Response Body
{
    "graph_read_mode": "OLTP_ONLY"
}

4.3.4.2.设置图的读模式

功能介绍

设置某个图的读模式. 该操作需要管理员权限

URI
PUT /graphspaces/${graphspace}/graphs/${graph}/graph_read_mode
URI参数
名称 是否必填 类型 默认值 取值范围 说明
graphspace String 图空间
graph String
Body参数
名称 是否必填 类型 默认值 取值范围 说明
ALL 或者 OLTP_ONLY String 合法的图模式包括:OLTP_ONLY,ALL
Response
名称 类型 说明
graph_read_mode String 图模式
使用示例
Method & Url
PUT http://localhost:8080/graphspaces/gs1/graphs/hugegraph/graph_read_mode
Request Body
"ALL"
Response Status
200
Response Body
{
    "graph_read_mode": "ALL"
}

results matching ""

    No results matching ""