本文介绍了如何在海王星中使用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的范围内可能是不可能的。

目前,如果您希望使用会话,则只能提交脚本。

这篇关于如何在海王星中使用Gremlin会话?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

11-03 09:34