#graphql #apollo-federation #联盟 #网关

graphgate-handler

GraphGate是使用Rust实现的Apollo Federation

4个版本 (2个破坏性更新)

0.5.1 2021年3月26日
0.5.0 2021年3月24日
0.4.0 2021年3月23日
0.3.2 2021年3月22日

#1417 in HTTP服务器

每月25次下载
graphgate 中使用

MIT/Apache

175KB
4.5K SLoC

GraphGate

GraphGate是使用Rust实现的Apollo Federation

快速开始

由3个服务(账户、产品、评论)组成的GraphQL API。

docker run -p 8000:8000 scott829/graphgate-standalone-demo:latest

打开浏览器 http://localhost:8000

执行查询

{
    topProducts {
        upc name price reviews {
            body
            author {
                id
                username
            }
        } 
    }
}

执行订阅

subscription {
    users {
        id username reviews {
            body
        }
    }
}

常见问题解答

Apollo Federation做什么?

为了充分利用GraphQL,您的组织应公开一个单一的数据图,它提供了一个统一的接口来查询任何组合的后备数据源。然而,使用单个、单体化的GraphQL服务器来表示企业规模的数据图可能具有挑战性。

为了解决这个问题,您可以使用Apollo Federation将您的图实现分割成多个可组合的服务

与其他分布式GraphQL架构(如模式拼接)不同,Apollo Federation使用声明式编程模型,使得每个实现服务只需实现其负责的图的部分。

为什么用Rust来实现它?

Rust是我最喜欢的编程语言。它安全且速度快,非常适合开发API网关。

GraphGate和Apollo Federation有什么区别?

我想GraphGate的性能会更好(我还没有做过基准测试,但很快就会添加),它支持订阅。

依赖关系

~15–33MB
~537K SLoC