0

我正在使用 java 注释生成 graphQL 模式。感谢graphql-spqr 库。我正在调用代码

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}.
 */

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

4

1 回答 1

1

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

你的用例到底是什么?为什么要在每次调用时构建一个新的模式实例?无论你想要达到什么目的——几乎肯定有更好的方法。

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

于 2018-04-22T15:42:33.490 回答