GraphQL模式生成

时间:2018-04-17 18:12:37

标签: facebook-graph-api graphql metrics graphql-js graphql-java

我正在使用java注释生成graphQL架构。感谢graphql-spqr library。我正在调用代码

GraphQLSchemaGenerator schemaGenerator = new GraphQLSchemaGenerator()
            .withResolverBuilders(new AnnotatedResolverBuilder())
            .withValueMapperFactory(new JacksonValueMapperFactory())
            .withOperationsFromSingleton(<annotatedClassObject>);
GraphQLSchema schema = schemaGenerator.generate();

每次调用graphQL API时都会执行上面的代码。我知道GraphQL Java库记录了以下行。

/** Building this object is very cheap and can be done on each 
  * execution * if necessary.  Building the schema is often not
  * as cheap, especially if its parsed from graphql IDL schema 
  * format via {@link graphql.schema.idl.SchemaParser}.
 */

有什么方法可以收集生成此架构的每次调用需要多长时间的指标?

1 个答案:

答案 0 :(得分:1)

我是graphql-spqr的作者。我可以告诉你的是,你肯定应该为每个请求调用它。 graphql-java文档引用的是GraphQL对象,构造起来确实很便宜,但架构不是。 SPQR在生成模式时扫描整个类层次结构,在一般情况下这是相当昂贵的。

你的用例到底是什么?为什么要在每次调用时构建一个新的模式实例?无论你想要实现什么 - 几乎可以肯定是一种更好的方式。

至于测量时间,您可以使用JMH(Java Microbenchmark线束)。