java - 无法从 JSON 格式的 gremlin 客户端检索查询结果

标签 java titan gremlin tinkerpop3

案例
我在 Java 中使用 ResultSet 的提交方法(由 org.apache.tinkerpop:gremlin-driver:3.0.1-incubating dependency 提供)来查询 gremlin 服务器。我需要知道如何配置我的客户端以接收 JSON 格式的响应。

我做了什么
我尝试同时使用 GraphSONMessageSerializerV1d0GraphSONMessageSerializerGremlinV1d0 序列化程序,但响应不是有效的 json。这是我的 gremlin-server.yaml 文件

authentication: {className: 
org.apache.tinkerpop.gremlin.server.auth.AllowAllAuthenticator,
config: null}
channelizer: 
org.apache.tinkerpop.gremlin.server.channel.WebSocketChannelizer
graphs: {graph: src/test/resources/titan-inmemory.properties}
gremlinPool: 8
host: localhost
maxAccumulationBufferComponents: 1024
maxChunkSize: 8192
maxContentLength: 65536
maxHeaderSize: 8192
maxInitialLineLength: 4096
metrics:
 consoleReporter: null
 csvReporter: null
 gangliaReporter: null
 graphiteReporter: null
 jmxReporter: null
 slf4jReporter: {enabled: true, interval: 180000, loggerName: 
org.apache.tinkerpop.gremlin.server.Settings$Slf4jReporterMetrics}
plugins: [aurelius.titan]
port: 8182
processors: []
resultIterationBatchSize: 64
scriptEngines:
gremlin-groovy:
config: null
imports: [java.lang.Math]
scripts: [src/test/resources/generate-asset-plus-locations.groovy]
staticImports: [java.lang.Math.PI]
scriptEvaluationTimeout: 30000
serializedResponseTimeout: 30000
serializers:
 - className: 
   org.apache.tinkerpop.gremlin.driver.ser.GryoMessageSerializerV1d0
   config: {useMapperFromGraph: graph}
 - className: 
  org.apache.tinkerpop.gremlin.driver.ser.GryoMessageSerializerV1d0
  config: {serializeResultToString: true}
 - className: 
   org.apache.tinkerpop.gremlin.driver.ser.GraphSONMessageSerializer
   GremlinV1d0
   config: {useMapperFromGraph: graph}
 - className: 
  org.apache.tinkerpop.gremlin.driver.ser.GraphSONMessageSerializerV1d0
  config: {useMapperFromGraph: graph}
  ssl: {enabled: false, keyCertChainFile: null, keyFile: null, keyPassword: 
   null, trustCertChainFile: null}
  threadPoolBoss: 1
  threadPoolWorker: 1
  writeBufferHighWaterMark: 65536
  writeBufferLowWaterMark: 32768

因此,如果有人可以帮助我配置客户端以接收 JSON 格式的结果,那就太好了!

最佳答案

要使用 GraphSON 作为序列化格式,您只需将其指定给 Cluster 构建器:

Cluster cluster = Cluster.build().serializer(Serializers.GRAPHSON_V2D0).create();

但是,这不会返回给您可使用的 JSON 字符串,这毫无意义。它告诉服务器使用 JSON 作为序列化格式,但驱动程序将 JSON 反序列化为对象( map 、列表等)。如果您想要一个实际的 JSON 字符串,那么您应该在发送到服务器的脚本中返回一个。您唯一的其他选择是编写您自己的序列化程序,它始终只保留字符串。

关于java - 无法从 JSON 格式的 gremlin 客户端检索查询结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44193097/

相关文章:

azure-cosmosdb - TinkerPop/CosmosDB 中的命令式匹配

Azure 数据库 - 架构设计规则

java - 从带有 JAVA 查询参数的链接下载图像

java - Spring Boot 登录登录返回 401 并匹配凭据

java - 如果 StringBuilder 无论如何都从 AbstractStringBuilder 继承它,为什么它应该实现 CharSequence 呢?

java - 如何从jSTL中的foreach循环获取索引值

java - Titan Graph 数据迁移

amazon-dynamodb - 使用适用于Titan的DynamoDB存储后端的DynamoDB定价

hadoop - 为 Spark 集群和 Cassandra 设置和配置 JanusGraph

schema - 如何删除 Titan DB 中的属性?