如何在海王星中使用Gremlin会话?
我正在尝试对Amazon海王星使用Gremlin sessions。我可以在会话之外很好地执行字节码查询,并且可以在会话客户端上运行字符串查询,但尝试使用会话客户端运行字节码查询会导致以下错误:
"code":"MalformedQueryException",
"detailedMessage":"Message with op code [bytecode] is not recognized."
我已完全按照AWS文档操作。
Cluster cluster = Cluster.build().with {
addContactPoint('host')
port(8182)
enableSsl(true)
serializer(Serializers.GRAPHBINARY_V1D0)
create()
}
def client = cluster.connect('session ID')
println client.submit('g.V()').all().get() // works
println traversal().withRemote(DriverRemoteConnection.using(client))
.V().iterate() // returns the error above
println traversal().withRemote(DriverRemoteConnection.using(cluster))
.V().iterate() // works, without a session
我使用的是Gremlin 3.4.8。如何使其正常工作?
解决方案
基于字节码的请求在海王星中根本不受支持(甚至作为参考实现的Gremlin服务器本身也不受支持)。造成这种差异的主要原因是,TinkerPop不想在已经使用的会话基础上进一步推广会话的使用。TinkerPop在很大程度上为工具支持的狭义用例构建了会话--例如Gremlin控制台远程连接、可视化工具包和图形分析工具。然而,考虑到Gremlin对远程多请求事务用例的弱支持,用户已经扩展了会话使用,以此作为解决该弱点的一种方法。
我感觉这种扩展可能会迫使TinkerPop在会话中提供字节码支持,但到目前为止还没有决定。另一种选择是改善对事务的支持,但考虑到这种变化的性质,这在TinkerPop 3.x的范围内可能是不可能的。
目前,如果您希望使用会话,则只能提交脚本。
相关文章