You need to enable JavaScript to run this app.
最新活动
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

ApolloFederation上两个微服务之间的突变问题

假设我们有两个拥有自己Schema的服务,一个是服务A,另一个是服务B。接下来,我们将通过Apollo联合将两个服务配置与联合网关E提供的入口点相连接。

那么,如果我在服务A中的逻辑中发生了变更,需要在服务B中更新这些变更呢?

这将需要发送一个查询到管家(gateway),询问 Schema 服务B是否要添加一些新字段。我们可以使用Apollo ServerApolloGateway来完成此操作。下面是一个示例:

const { ApolloGateway, RemoteGraphQLDataSource } = require('@apollo/gateway');

class RemoteSchemaService extends RemoteGraphQLDataSource {
    willSendRequest({ request, context }) {
        request.http.headers.set('my-header', context.myHeader);
    }
}

const gateway = new ApolloGateway({
    serviceList: [
        { name: 'serviceA', url: 'http://localhost:4001/graphql' },
        {
            name: 'serviceB', url: 'http://localhost:4002/graphql', 
            dataSource: new RemoteSchemaService()
        }
    ]
});

const server = new ApolloServer({
    gateway,
    subscriptions: false,
});

server.listen(4000).then(({ url }) => {
    console.log(`� Server ready at ${url}`);
});

使用 RemoteGraphQLDataSource 作为数据源将允许我们修改传出请求的标头(headers),并将其传递到下游服务。在这个示例中我们设置了一个叫做 my-header 的标头。

现在,我们可以在服务B中使用 ApolloServerPluginSchemaReporting 来将使用情况的情况发送回AP散列表(Apollo Platform Hash)中心。这样可以确保突变的信息可在适当的时间进行收集。以下是具体示例:

const { ApolloServerPluginSchemaReporting } = require('apollo-server-core');

const server = new ApolloServer({
    schema,
    plugins: [
        ApolloServerPluginSchemaReporting({
            // 在这里配置你的上报选项
        })
    ]
});

server.listen().then(({ url }) => {
    console.log(`� Server ready at ${url}`);
});

ApolloServerPluginSchemaReporting 函数中读取的获得的类似于下面的信息:

[
  {
    "schemaHash": "c2c26a0f2534744c44ce92ff6c4cbeddbbc
本文内容通过AI工具匹配关键字智能整合而成,仅供参考,火山引擎不对内容的真实、准确或完整作任何形式的承诺。如有任何问题或意见,您可以通过联系service@volcengine.com进行反馈,火山引擎收到您的反馈后将及时答复和处理。
展开更多
面向开发者的云福利中心,ECS 60元/年,域名1元起,助力开发者快速在云上构建可靠应用

社区干货

特惠活动

热门爆款云服务器

100%性能独享,更高内存性能更佳,学习测试、web前端、企业应用首选,每日花费低至0.55元
60.00/1212.00/年
立即购买

域名注册服务

cn/top/com等热门域名,首年低至1元,邮箱建站必选
1.00/首年起32.00/首年起
立即购买

DCDN国内流量包100G

同时抵扣CDN与DCDN两种流量消耗,加速分发更实惠
2.00/20.00/年
立即购买

ApolloFederation上两个微服务之间的突变问题 -优选内容

ApolloFederation上两个微服务之间的突变问题 -相关内容

特惠活动

热门爆款云服务器

100%性能独享,更高内存性能更佳,学习测试、web前端、企业应用首选,每日花费低至0.55元
60.00/1212.00/年
立即购买

域名注册服务

cn/top/com等热门域名,首年低至1元,邮箱建站必选
1.00/首年起32.00/首年起
立即购买

DCDN国内流量包100G

同时抵扣CDN与DCDN两种流量消耗,加速分发更实惠
2.00/20.00/年
立即购买

产品体验

体验中心

云服务器特惠

云服务器
云服务器ECS新人特惠
立即抢购

白皮书

一图详解大模型
浓缩大模型架构,厘清生产和应用链路关系
立即获取

最新活动

爆款1核2G共享型服务器

首年60元,每月仅需5元,限量秒杀
立即抢购

火山引擎增长体验专区

丰富能力激励企业快速增长
查看详情

数据智能VeDI

易用的高性能大数据产品家族
了解详情

一键开启云上增长新空间

立即咨询