- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的公司采用面向服务的架构。因此,我的应用程序的 GraphQL 服务器必须调用其他服务来满足来自前端的数据请求。
假设我的 GraphQL 架构定义了类型 User
。该类型的数据有两个来源:
用户名
、年龄
和 friend
。用户
相关数据:favoriteFood
、favoriteSport
。 假设用户帐户服务的端点自动返回用户名
和年龄
,但您必须传递查询参数friends=true
为了检索 friend
数据,因为这是一项昂贵的操作。
考虑到这一背景,以下查询在 getUser
解析器中提出了一些优化挑战:
query GetUser {
getUser {
username
favoriteFood
}
}
挑战#1当 getUser
解析器向用户帐户服务发出请求时,它如何知道是否也需要请求 friends
数据?
挑战#2当解析器查询我的应用程序的数据库以获取其他用户数据时,它如何知道要从数据库中检索哪些字段?
针对这两个挑战,我能找到的唯一解决方案是通过解析器收到的第四个 info
参数检查解析器中的查询。这将允许它找出是否应该在对用户帐户服务的 REST 调用中请求 friends
,并且它将能够构建正确的 SELECT
查询来检索需要来 self 的应用程序数据库的数据。
这是正确的方法吗?这似乎是 GraphQL 实现必须始终遇到的一个用例,因此我希望遇到一个被广泛接受的解决方案。然而,我没有找到很多文章来解决这个问题,也不存在广泛使用的 NPM 模块( graphql-parse-resolve-info 是 PostGraphile 的一部分,但每周下载量只有约 12k,而 graphql-fields 每周下载量约为 18.5k) .
因此,我担心我遗漏了一些关于如何完成此操作的基本知识。我是吗?或者检查 info
参数是解决这些优化挑战的正确方法吗?如果重要的话,我正在使用 Apollo Server。
最佳答案
如果您想根据请求的选择集修改解析器,实际上只有一种方法可以做到这一点,那就是解析请求的查询的 AST。根据我的经验,graphql-parse-resolve-info
是使解析不那么痛苦的最完整的解决方案。
我想这并不像您想象的那么普遍,因为我想大多数人都属于以下两类之一:
在后一种情况下,表示关联的字段会被赋予自己的解析器,因此除非实际请求,否则不会触发对数据库的后续调用。 Data Loader然后用于帮助批处理所有这些对数据库的额外调用。对于最终调用其他数据源(例如 REST API)的字段也是如此。
在这种特殊情况下,Data Loader 对您没有太大帮助。最好的方法是为 getUser
使用一个解析器,从数据库和 REST 端点获取用户详细信息。然后,您可以按照您已经计划的那样,根据请求的字段调整这些调用(或完全跳过它们)。这可能很麻烦,但会按预期工作。
此方法的替代方法是简单地获取所有内容,但使用缓存来减少对数据库和 REST API 的调用次数。这样,您每次都会获取完整的用户,但除非缓存失效或过期,否则您将从内存中获取完整的用户。这更加消耗内存,并且缓存失效总是很棘手,但它可以显着简化您的解析器逻辑。
关于optimization - 优化 SQL 数据库和面向服务的架构中的 GraphQL 解析器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57650235/
我正在创建一个多区域 AlwaysOn Sql Availability 组。我在东部有 2 个虚拟机,在西部有 1 个虚拟机。我需要使用面向公众的负载平衡器对这些进行负载平衡。是否可以使用存在于不同
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我是 Smalltalk 技术的新手。我的编程经验是使用 C 和 C++。我想了解smalltalk的设计方法论。谁能推荐一些用smalltalk开发的简单的实时应用程序,可以帮助像我这样的初学者探索
现在我已经对 web2py 比较熟悉了,我想试试 Django。 主要区别是什么? 考虑到 web2py 知识,最有效的入门方法是什么? (一定有一些python应用框架的知识,不是吗?) 编辑 另外
我之前发过一个问题,Moving away from VSS ,其中我向使用 VSS 的 Delphi 开发人员询问了最佳的 VCS 控件。大多数开发人员似乎将 svn 与 TortoiseSVN 一
引用this question ,收集对 Delphi 初学者真正有帮助的网站链接可能会很好。 第一个答案指向Delphi Basics ,这是一个非常好的网站。 但一定还有更多。 所以:请为这个社区
我已经构建了一个 saas 产品,其中 Angular 4 与 golang Rest api 集成,并将构建上传到了 aws ec2 实例上。我的项目是一个基于 Multi-Tenancy 的应用程
我是 .NET 开发人员,在此之前使用过 VB6。我已经非常熟悉这些环境,并在垃圾收集语言的上下文中工作。但是,我现在希望通过 native C++ 增强我的技能,但发现自己有点不知所措。具有讽刺意味
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
由于我在数学方面没有任何出色的技能,所以我问您是否存在我应该在未来可能会改变的类(class)中使用的算法。 考虑以下场景: “角色”类具有以下字段: private boolean admin; p
我有许多面向“列”的 csv 文件,我需要对其进行预处理才能最终索引它们。 这是面向时间的数据,每个“设备”都有大量的列(最多 128 列),例如: LDEV_XXXXXX.csv
我想就重构技巧的最佳资源展开讨论,着眼于前端 JavaScript 重构。 一个我尊重其意见的 friend 建议这个 book ,尽管它使用 Java 中的示例。我明白 OO 重构的原则应该翻译成另
我不明白如何使用 Jquery/javascript 处理对象。 以及如何创建私有(private)方法/变量?我在论坛上看到关闭,但我尝试过但没有用。以及如何查看方法/变量是否是私有(private
我已经使用 MATLAB 多年并且非常熟练。我习惯了 MATLAB 调试,您可以在其中跳过行并查看变量及其变化方式,这就是我学习编码的方式。我现在正在研究使用 FORTRAN、C++ 和 Python
我正在学习如何实现“单一 Activity - 多个 fragment ”架构。据我所知,这是如今很普遍的方法,你可以找到很多关于这个主题的文章。例如这个 http://vinsol.com/blog
目前是否有任何简单的方法可以在 Apache Tomcat Servlet 容器前面设置 YAWS Web 服务器,类似于流行的 Apache httpd + Tomcat 设置? 最佳答案 我不相信
我是一个相当有能力的 Ruby 脚本编写者/程序员,但一直感到要扩展到 C++ 的压力。我没能找到任何与“C++ for Ruby Programmers”相关的网站。 This site Pytho
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 5 年前。
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我在表上有一个名为 cart_product_fti 的全文索引 每当我使用它时,我都必须准确列出索引中的所有字段: MATCH (foo,bar,etc) 我的想法是,如果稍后我决定向索引添加/删除
我是一名优秀的程序员,十分优秀!