我们常常会遇到这种情况,我有一个程序在 Linux 系统中运行了几个月。当我想修改它的代码时,却忘记了这个程序放在哪里。 如下图所示,忘记 test.py 这个文件在哪里了: ?...如果你的电脑是 Linux 系统,那么解决方法非常简单,不需要安装任何第三方程序。只需要几行命令即可。 首先,使用ps -aux | grep xxx找到这个程序的pid,如下图红框所示: ?...其中,我们需要的是 cwd这个文件。 这些文件都是软连接。我们可以使用ls -l cwd查看cwd这个软连接指向的真实地址。这个地址就是我们这个程序所在的位置,如下图所示: ?
GraphQL 是 Facebook 于 2012 年在内部开发的数据查询语言,在 2015 年开源,旨在提供 RESTful 架构体系的替代方案。...感觉这是一个让广大(前端)开发者(重新)认识学习 的好机会,就让我们来回顾一下它~ 从 Graph 字面开始 先看官网的解释~ GraphQL 既是一种用于 API 的查询语言也是一个满足你数据查询的运行时...GraphQL 有配套的数据库服务, graphcool 可以部署在 Docker 上或运行在基于 BaaS(Backend as a Service) 的 Graphcool Cloud。...这意味可能同时有 52 个版本的客户端查询我们的服务端,而在 Fackbook 中 GraphQL API 曾支持了横跨 3 年的移动端) 自检性: 能在执行 之前(即在开发时)提供描述性错误消息,...后一个工具可把笔者惊艳坏了,想了解它的生态可以在 awesome-graphql 里寻找。通过它们,所有人都能快速阅读查询文档,调试我们的查询。
GraphQL 既是一种用于 API 的查询语言也是一个满足你数据查询的运行时。...输出可以是其他模式语言,比如protobuf或JSON schema,也可以是当前支持Go、Ruby和Python的代码。 公共数据模型的好处在于能够轻松地在多个团队和服务之间传播其实现。...构建管道将监视特性分支上的模式更改,并启动第二个管道来生成所有目标语言的输出。将输出提交回特性分支,开发人员可以在合并到主分支之前检查更改。...在NSA中没有对端点、订阅者或发布者的引用。来自NSA的输出代码可以被任何自己管理传输方法的适配器使用。 InfoQ:你还考虑过其他什么设计,你怎么认为这是最好的方法?...InfoQ:GraphQL模式是存储在单独的repos中,还是存储在生产者或消费者中? Nav开发团队:GraphQL模式当前存储在与处理器和随后生成的代码相同的存储库中。
粗粒度的接口导致不必要的数据传输,细粒度的接口导致函数爆炸,你见过 JavaScript 的 Promise 满天飞吧。...简单来说,GraphQL 是一种面向数据的 API 查询风格,把所有数据都视为已连接的图形,客户端能够准确地获得它需要的数据,没有任何冗余,也让 API 更容易地随着时间推移而演进,还能用于构建强大的开发者工具...GraphQL 的支持,比如 JavaScript/Nodejs、Java、PHP、Ruby、Python、Go、C# 等。...据一位在 Twitter 工作的大佬说硅谷不少一线二线的公司都在想办法转到 GraphQL 上,但是同时也说了 GraphQL 还需要时间发展,因为将它使用到生产环境需要前后端大量的重构,这无疑需要高层的推动和决心...最后的话 GraphQL 已经被各种体量的团队所使用,在不同的环境、不同的语言下,用于增强移动应用、网站和 API。如果你已经厌倦了 REST API,现在是时候学习一下 GraphQL 了。
而我们选择了立足 Fastly 层级对部分 GraphQL 请求进行缓存: 我们的 React 应用会标注出那些可进行缓存的 GraphQL 查询。...在发送 HTTP 请求之前,我们以请求本体为基础构建一条附加 URL 参数,其中包含 GraphQL 查询与变量(我们配合 Apollo Client 使用自定义 fetch)。...这意味着我们可以通过请求本体当中的 GraphQL 查询不断发送 POST 请求,并在无需接触服务器的前提下立足边缘位置完成缓存。 ?...利用持久化 GraphQL 查询并发送 GET /graphql/:queryId 以使用 HTTP 缓存机制。...在 CI 中运行 Lighthouse。 渐进式 hydration 与 React 流式设计。 另外还有更多令人兴奋的想法可供尝试。
如何发现端点 1、BurpSuite 使用bp在扫描过程中自动测试GraphQL端点,找到会引发找到GraphQL端点问题。...2、通用查询 如果发送query{__typename}到任何 GraphQL 端点 它将{"data": {"__typename": "query"}}在其响应中的某个位置包含该字符串。...注:GraphQL服务通常对任何非GraphQL请求做出查询不存在或者错误的响应。...用户只需要提供正确的参数,就可以访问到一些未授权信息,成为IDOR 如何发现GraphQL架构信息 最好的方式是使用自省查询,自省是一个内置的GraphQL函数,可以让我们查询服务器以获取相关的架构信息...,我们可以发送到重发器,最新版的bp可以在其中找到GraphQL 自省启动了但查询未运行 如果启用了自省但上述查询未运行,尝试从查询结构中删除onOperation、onFragment和指令。
我们将会用Nodejs来完成这个任务,因为这个语言我们已经在marmelab用了4年了。但你也可以用任何你想用的语言,例如Ruby,Go,甚至PHP,JAVA或C#。 ?...我会和产品和前端开发团队一起来讨论需要提供哪些数据类型,查询或更新操作。如果你了解领域驱动设计方法[4],你会很熟悉这个流程。前端开发团队在拿到服务端返回的数据结构之前是没有办法开始编码的。...Graphql服务根据我们提供的schema定义,在执行请求携带的查询语句之前进行了必要的校验,如果我们的查询语句中包含了一个没有声明过的字段,我们会得到一个错误提醒: > curl 'http://localhost...日志 除了数据和错误外,graphQL的响应中还可以包含extensions类信息,你可以在其中放你想要的任何数据。我们用它来显示服务的耗时信息再好不过了。...一些教程推荐使用graphQL的Mutation来实现注册和登录功能[21],并且在resolver函数中实现认证逻辑。但我的观点是,这在多数场景中都显得过火了。
一、GraphQL 模式出现的必然性 面向前端页面的数据聚合层,其接口很容易在迭代过程中,变得愈加复杂;最终发展成一个超级接口。...仿照格林斯潘第十定律: 任何C或Fortran程序复杂到一定程度之后,都会包含一个临时开发的、不合规范的、充满程序错误的、运行速度很慢的、只有一半功能的Common Lisp实现。...我编写了一个简单的 Resolver 函数,用来演示查询结果。 ? 它很简单。Query 里返回跟字段名一样的字母,任何子节点的数据,都是拼接父节点的字母串。...七、我们的 GraphQL-BFF 实践模式 在掌握上述关于 GraphQL 的纲领知识后,我们来看一下在实践中 ,GraphQL-BFF 的一种实际做法。...编写一个中间件,在 next 之前,挂载一些方法,供后续中间件使用;在 next 之后,拿到 graphql 的查询结果,进行额外的处理。
在传统的基于 REST 的 API 方法中,客户端发出请求,而服务端决定响应。 但是在 GraphQL 中,客户端可以精确地确定其从服务器获取的数据。...但是,与任何框架或语言一样,GraphQL 也需要权衡取舍。在本文中,我们将探讨使用 GraphQL 作为 API 查询语言的利弊,以及如何开始构建实现。...定义一个 GraphQL Schema 有各种编程语言的 GraphQL 服务器实现,但在你开始之前,你需要识别你的业务域中的对象,就像任何 API 一样。...} } } 这个解析器需要两个参数:一个代表父的对象(在最初的根查询中,这个对象通常是未使用的),一个包含传递给你的字段的参数的 JSON 对象。...在左侧窗格中,你可以输入所需要的任何有效 GraphQL 查询,而在右侧获得结果。
我们使用 GQLMS 进行了快速的概念验证应用,其经验证实了 GraphQL 宣传其好处时所提出两个理论: GraphiQLIDE 在模式(schema)旁边显示任何可用的 GraphQL 文档,从而极大地改善了...1Graphile 在早期的 GraphQL 探索过程中,Netflix 的工程师意识到 Graphile 库可以将 PostgreSQL 数据库对象(表、视图和函数)作为 GraphQL API 来呈现...关于最后一点:更改表中列的类型将会打破关联的视图,但是通过封装在事务中的更改,可以删除视图、更新该列,然后可以在提交事务之前重新创建视图。...我们在启用 pgWatch 的情况下运行 Graphile,只要对数据库做任何更新,GraphQL 模式就会立即更新以反映所做的更改。...向 Graphile 生成的模式中添加自定义查询和突变(即公开 UI 所需的 gRPC 服务调用)是我们目前在 Docker 镜像中不支持的。
关于graphw00f: graphw00f是一款针对GQL节点的GraphQL指纹识别工具,该工具可以混合发送良性和恶意查询请求,以帮助广大研究人员识别和确定目标应用程序背后的GraphQL引擎。...精心构建的查询请求会导致不同的GraphQL服务器实现对查询、突变和订阅做出不同的响应,以实现我们对后端引擎进行指纹识别并区分不同的GraphQL实现。...- Go gqlgen - Go WPGraphQL - PHP GraphQL API for Wordpress - PHP Ruby - GraphQL graphql-php - PHP Hasura...工具使用: 识别GraphQL指纹 在这个例子中,我们将识别一个GraphQL节点的具体位置: python3 main.py -f -t https://demo.hypergraphql.org:8484...检测和识别GraphQL指纹: 在这个例子中,graphw00f可以检测GraphQL的活动状态,并执行指纹识别进程: python3 main.py -f -d -t http://localhost
3.1模式,类型和字段 模式定义了可以在GraphQL查询中使用的类型和字段。GraphQL不受任何特定的DSL或编程语言的束缚。...解析函数是我掌握的最难的部分,在查看真正的帐户查询的解析函数时,我们会稍微看到更多的解析代码。...在指定的“AllAccountsResolverFunc”函数中,可以将单个“name”参数实现为一个“like”搜索或类似的查询。...这个initQL 函数是我们在第三节中看到过的一个,设置了我们的模式,字段等内容。 我们声明了一个用于将变量传递到查询执行中的String => interface {}映射。...我们只需要确保initQL(..)在我们的实时解析器函数的某个地方被调用,例如在初始化路由之前的router.go中: func NewRouter() *mux.Router { initQL(&LiveGraphQLResolvers
有真正的好处吗?JsonAPI 和 GraphQL 是新标准吗?根据受欢迎程度更改公共 api 实现似乎没有用,尤其是在没有太大好处的情况下。 有人可以启发我吗?...它们都描述了用于创建和使用 RESTful API 的标准协议。GraphQL 是一种完全不同的 API 设计方法,并指定了一种查询 API 资源的不同方式。...GraphQL: 自 2015 年以来在 Facebook 开发。该规范仍是工作草案。它在 React 爱好者中很受欢迎,主要与 React 或 Vue.js 结合使用。...为了清楚和完整起见,我将 OpenAPI 包括在列表中,尽管它并不完全是 API 规范。这可能会让一些人感到困惑。 OpenAPI 标准是一种与语言无关的标准,用于描述和定义 API。...总之,OData 和 JSON API 都是 JSON 数据格式,它们在数据周围添加上下文和特征(例如链接),GraphQL 是一种完全不同的查询和变异 JSON 数据的新方法,而 OpenAPI 是声明和记录任何数据的标准方法
传统的 API 拿到的是前后端约定好的数据格式,GraphQL 对 API 中的数据提供了一套易于理解的完整描述,客户端能够准确地获得它需要的数据,没有任何冗余,也让 API 更容易地随着时间推移而演进...对象类型:用户在 schema 中定义的 type 标量类型:GraphQL 中内置有一些标量类型 String、Int、Float、Boolean、ID,用户也可以定义自己的标量类型 比如在 Schema...注意:在 Query 查询字段时,是并行执行的,而在 Mutation 变更的时候,是线性执行,一个接着一个,防止同时变更带来的竞态问题,比如说我们在一个请求中发送了两个 Mutation,那么前一个将始终在后一个之前执行...args:查询中传入的参数 context:提供给所有解析器的上下文信息 info:一个保存与当前查询相关的字段特定信息以及 schema 详细信息的值 解析函数的返回值可以是一个具体的值,也可以是...一些常用的解决方案如 Apollo 可以帮省略一些简单的解析函数,比如一个字段没有提供对应的解析函数时,会从上层返回对象中读取和返回与这个字段同名的属性。
由于 GraphQL 是通过单个端点运行的,因此端点响应的数据完全取决于你的查询。这个查询需要正确格式化 GraphQL。想知道如何构建查询吗?请查阅关于如何编写 GraphQL 查询的教程。...当查询包含多个命名操作的查询时,它用于指定要运行的操作。 如果你将一个 GraphQL 作为一个 GET 请求发送,则需要将以上内容作为查询参数传递。...: https://stepzen.com/request-invite GraphQL 请求的基础知识 我们可以通过不带任何特殊库的 Node.js 发送查询,利用标准的 Node https 库格式化一个...', }, } ); const json = await response.json(); console.log(json.data); } getData(); 运行上面代码的结果与我们之前的示例相同...更好的解决方案是调用一个可访问这些凭据的无服务器函数,然后为你调用 API 并返回结果。如果你的无服务器函数是用 JavaScript 编写的,则前面示例中的 Node 代码就会起作用。
但是 Rust 的内存规则并不比 Node.js 或 Python 更安全,用 Rust 编写的 Web 应用程序在系统上不会比 Python 或 Ruby 应用程序安全。...这是技术选择中的重要部分:是否有人在使用该工具?他们大致在同一个领域吗?不幸的是,Rust 生态系统中许多令人难以置信的令人兴奋的工作与 Web 应用服务器无关。...我们有很多方法来尝试和解决这些问题:你可以编写 SQL,并尝试使用 CTE 和 JOIN 在单个查询中完成大量工作,就像我们在 Observable 中所做的那样,或者使用像 ActiveRecord...Juniper 是一个用于 Rust 应用程序的 GraphQL 服务。GraphQL 基本上都是由前端应用程序定义查询,而不是后端。...任何 SQL 级别的优化都不可能做到——你的服务器正在编写动态 SQL,优化只能依赖 GraphQL 服务,但它不会总是有效。
左边为之前的logo,右边为新logo Appwirte是什么 Appwrite是一个基于Docker的端到端开发者平台,其容器化的微服务库可应用于网页端,移动端,以及后端。...Appwrite 通过视觉化界面简化了从零开始编写 API 的繁琐过程,在保证软件安全的前提下为开发者创造了一个高效的开发环境。...您可以使用 docker-compose 在本地主机上运行 Appwrite,也可以在任何其他容器化工具(如 Kubernetes、Docker Swarm 或 Rancher)上运行 Appwrite...在运行安装命令之前,请确保您的机器上安装了 Docker: Linux & Macos docker run -it --rm \ --volume /var/run/docker.sock:/...Serverless Function 使用Function可以自定义和扩展你的后端,部署和扩展在安全、隔离的运行时中运行的无服务器函数。
它是数据库无关的,而且可以在使用API的任何环境中有效使用,我们可以理解为GraphQL是基于API之上的一层封装,目的是为了更好,更灵活的适用于业务的需求变化。...GraphQL的这种思考模式是不是完美解决了之前遇到的问题呢?!...总结它的好处: 在它的设计思想中,GraphQL 以图的形式将整个 Web 服务中的资源展示出来,客户端可以按照其需求自行调用,类似添加字段的需求其实就不再需要后端多次修改了。...服务端实现 在服务端, GraphQL 服务器可用任何可构建 Web 服务器的语言实现。...Graphql的一些工具 graphiql (npm): 一个交互式的运行于浏览器中的 GraphQL IDE。
领取专属 10元无门槛券
手把手带您无忧上云