JanusGraph将子图输出为GraphSON错误

时间:2017-05-12 19:57:03

标签: java groovy titan gremlin janusgraph

我试图用JanusGraph在Gremlin shell中输出一个子图作为GraphSON。

TinkerPop文档供参考: http://tinkerpop.apache.org/docs/current/reference/#graphson-reader-writer

当我编写完整的图形时,这很好,但是,当我想编写一个我使用这些命令查询的子图时:

gremlin> subGraph = g.V(45240).repeat(__.bothE().subgraph('subGraph').bothV()).times(4).cap('subGraph').next()

我使用相同的写命令:

gremlin> subGraph.io(IoCore.graphson()).writeGraph("45240_sub4.json")

我收到此错误:

  

(是java.lang.IllegalStateException)(通过引用链:org.janusgraph.graphdb.relations.RelationIdentifier [“inVertexId”])

搜索周围,我发现另一个线程说我需要导入一个包以便正确地执行此操作(对于TitanGraph,但我认为它也适用于JanusGraph):Import package in gremlin

但是,每当我尝试导入时:

gremlin>  import com.thinkaurelius.titan.graphdb.tinkerpop.io.graphson.TitanGraphSONModule

我收到此错误:

  

无效的导入定义:'com.thinkaurelius.titan.graphdb.tinkerpop.io.graphson.TitanGraphSONModule';原因:启动失败:   script1494618250861805544050.groovy:1:无法解析类com.thinkaurelius.titan.graphdb.tinkerpop.io.graphson.TitanGraphSONModule    @第1行,第1列。      import com.thinkaurelius.titan.graphdb.tinkerpop.io.graphson.TitanGraphSONModule      ^

     

1错误

如何使用JanusGraph在Gremlin shell中将子图输出为GraphSON?

2 个答案:

答案 0 :(得分:6)

当您使用subgraph()步骤时,结果为TinkerGraph,但其顶点和边缘ID是从JanusGraph实例转移的。特别是,边缘ID的类型为RelationIdentifier,需要JanusGraph的自定义序列化程序JanusGraphSONModule才能完全导出。

以下是一个基于Titan的previous example的示例,您可以在Gremlin控制台中运行:

graph = JanusGraphFactory.open('inmemory')
graph.io(graphson()).readGraph('data/tinkerpop-modern.json')
g = graph.traversal()
subGraph = g.E().hasLabel('knows').subgraph('sg').cap('sg').next()
graphsonIO = IoCore.graphson().graph(subGraph).registry(JanusGraphIoRegistry.getInstance()).create()
graphsonIO.writeGraph('/tmp/subgraph.json')

答案 1 :(得分:1)

您可能只需导入该Titan模块的JanusGraph等效项:org.janusgraph.graphdb.tinkerpop.io.graphson.JanusGraphSONModule

所以,这个导入应该有效:

gremlin>  import org.janusgraph.graphdb.tinkerpop.io.graphson.JanusGraphSONModule