首页
/ Apollo Router v1.60.1 版本发布:关键修复与优化

Apollo Router v1.60.1 版本发布:关键修复与优化

2025-07-10 07:41:41作者:虞亚竹Luna

Apollo Router 是一个高性能的 GraphQL 网关,用于构建和管理 GraphQL API。作为 Apollo GraphQL 平台的核心组件,它能够聚合多个数据源,提供统一的 GraphQL 接口,同时具备强大的性能优化和安全特性。

头部传播规则修复

本次版本修复了头部传播规则中的一个重要问题。在之前的版本中,头部传播逻辑存在缺陷,导致无论规则是否匹配,头部都会被标记为已传播。这影响了某些特定配置下的头部传播行为。

修复后,只有当头部确实被填充时才会被标记为固定。例如,以下配置现在可以正常工作:

headers:
  all:
    request:
      - propagate:
          named: a
          rename: b
      - propagate:
          named: b

需要注意的是,如果为头部设置了默认值,则该头部会被视为已填充。因此,建议将默认值设置放在传播规则的最后:

headers:
  all:
    request:
      - propagate:
          named: a
          rename: b
      - propagate:
          named: b
          default: defaulted

实体缓存控制头优化

修复了实体缓存中 cache-control 头指令冲突的问题。现在,当请求解析时,路由器会过滤掉 cache-control 头中不必要的值。例如,如果原始头包含 max-age=10, no-cache, must-revalidate, no-store,优化后将只保留 no-store,因为这是最严格的缓存控制指令。

这一改进遵循了 HTTP 缓存控制的最佳实践,确保了缓存行为的正确性和一致性。

片段压缩算法优化

在 v1.58.0 版本中引入的新片段压缩策略在某些情况下出现了性能回退。本次更新进一步优化了压缩算法,显著改善了处理大型操作时的性能表现:

  • P99 延迟开销降低至仅 10ms
  • 在最佳情况下,P99 级别的操作体积缩小了 50Kb
  • 在最差情况下,P99 级别仅增加了 108 字节的额外开销

这些改进使得压缩算法在各种场景下都能提供更优的性能表现,同时保持了代码的简洁性。

总结

Apollo Router v1.60.1 版本主要针对头部传播、缓存控制和片段压缩等核心功能进行了重要修复和优化。这些改进不仅解决了已知问题,还进一步提升了系统的稳定性和性能表现。对于使用这些特性的用户来说,升级到最新版本将获得更可靠和高效的 GraphQL 网关体验。

登录后查看全文
热门项目推荐

热门内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
860
511
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
259
300
kernelkernel
deepin linux kernel
C
22
5
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
595
57
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K