NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

《卫报》优化了移动推送通知投递架构

  • 2023-05-25
    北京
  • 本文字数:1219 字

    阅读完需:约 4 分钟

《卫报》优化了移动推送通知投递架构

《卫报》(The Guardian)的技术团队已经在着手加快移动推送通知的速度,以改善读者的体验。针对并发性进行优化的原始架构一直受到通知投递延迟的困扰。工程师们利用改进的可观测性,通过实验获得了显著的成果。


《卫报》的读者可以使用移动应用程序访问内容,并可以通过注册以推送通知的形式接收突发新闻提醒。其背后的事件驱动架构(EDA)自 2009 年以来一直在运行,但随着时间的推移,通知投递的时间有所增加,对某些用户来说,通知投递时间需要五分钟以上。


《卫报》的全栈开发人员Francesca Hammond表示,该团队的目标是在两分钟内向 90%的预期受众发送通知,这一目标被称为“90in2”。


支持推送通知投递的解决方案利用了一系列的技术。一个与Scala Play应用程序对话的内部突发新闻工具触发推送通知投递。AWS Lambda函数使用来自AWS SQS的队列消息,负责从自托管的PostgreSQL数据库中获取通知注册,并将其发送到谷歌和苹果的推送通知平台。



来源: https://www.theguardian.com/info/2022/dec/15/our-journey-towards-the-fastest-breaking-news-service


该团队使用ELK栈改进了整个过程的可观测性,这对于识别瓶颈至关重要。


他们认为检索通知注册是造成延迟的主要瓶颈。进一步的调查发现存在大量的数据库连接错误,从而导致处理时间过长。为了解决这个问题,团队引入了RDS代理,这样 lambda 函数就不会直接连接到数据库,从而避免了触达数据库的连接限制。


查询执行时间过长被认为是延迟的另一个原因。在判定查询计划是正确的之后,为了进一步提高数据库性能,一个完整的真空进程删除了“死行”(数据库仍保留的逻辑删除行),并将数据库从版本 10 升级到了版本 13,该版本允许使用更强大的 AWS Gravitron2 处理器。


团队通过创建一个新的 RDS 实例来升级数据库,以最大限度地减少切换过程中的停机时间。他们设置了逻辑复制来持续同步数据,而应用程序服务则使用旧实例。在切换时,团队更新服务以使用新实例,并立即禁用逻辑复制。



来源: https://www.theguardian.com/info/2022/dec/15/our-journey-towards-the-fastest-breaking-news-service


在持久层之外,开发人员发现,负责向苹果/谷歌平台提交通知的lambda函数需要长达六分钟的时间才能完成接收人数超过 80 万的突发新闻。


该团队通过部署潜在的优化并观察结果进行了几次实验,每次都需要决定更改的保留和恢复。基于这些实验,他们增加了运行在 lambda 函数中的 Scala 应用程序的线程池大小,以提高并行性。此外,他们还将 lambda 函数可用的内存和 CPU 数量设置为支持的最大值,从而缩短了函数的执行时间。


Hammond 写道,继续之前,团队正在进行评估:

我们还没做完呢!我们认为,为了实现 90in2 的目标,可能需要对我们的架构进行更大的更改,特别是考虑到向 200 多万订阅者发送更大的通知时。由于所需更改的性质,我们想尝试实施 RFC 风格的流程,以便在开始开发之前收集想法和反馈。


《卫报》的核心通知平台是开源的


原文链接:

https://www.infoq.com/news/2023/05/guardian-push-architecture/

2023-05-25 12:032818

评论

发布
暂无评论
发现更多内容

前端开发还可以这么玩?元数据实践分享

华为云开发者联盟

大前端 元数据 组件 ROMA 业务流

甲方日常 64

句子

工作 随笔杂谈 日常

百篇已过,又是一个新篇章,谈谈感受吧

良知犹存

代码人生

拆解增长黑客之实战(二):留存与变现

懒杨杨

读书 增长 产品运营

报销发票抵扣工资的CTO,该不该? | 法庭上的CTO(5)

赵新龙

CTO 法庭上的CTO

面试被问线程安全怎么保障,我的回答让面试官眼前一亮

996小迁

Java 架构 面试 多线程

Spock单元测试框架实战指南四 - 异常测试

Java老k

Java 单元测试 spock

谷燕西:不需要银行的银行业务

CECBC

移动互联网

《Python深度学习》第二版重磅来袭——(Keras之父亲自编写)

计算机与AI

构师训练营 - 第七周课后练习

joshuamai

云原生架构:容器资源限制及资源可见性

云原生实验室

云原生

数字经济跨越五个融合发展阶段,区块链正成为基础支撑结构

CECBC

数字经济

Redis 持久化方式-RDB

码农架构

redis redis持久化

mongodb 源码实现系列 - command 命令处理模块源码实现二

杨亚洲(专注MongoDB及高性能中间件)

MySQL mongodb 分布式数据库 源码刨析 分布式数据库mongodb

Windows下MySQL无法启动万能解决方案

MySQL从删库到跑路

MySQL

第六周-作业1

Mr_No爱学习

构师训练营 - 第七周学习总结

joshuamai

2. Spring早期类型转换,基于PropertyEditor实现

YourBatman

Spring Framework 类型转换 PropertyEditor

Bitmap为什么那么快?

Man

redis 中间件

Redis 子进程开销监控和优化方式

码农架构

Redis开发与运维

第十一周作业

solike

警察营救安徽望江县17岁女生跳河自尽过程中,现场看热闹的旁观者们在做什么?

wbliu85

告别“效率内卷化”,华为用一年时间让职场人支棱起来

脑极体

国家计算机网络与信息安全管理中心官员:数字货币的风险仍需关注

CECBC

信息安全

Newbe.ObjectVisitor 0.4.4 发布,模型验证器上线

newbe36524

.net core ASP.NET Core dotnet

算法训练营课程纲要

陈皓07

架构词典:语言

lidaobing

架构 语言

基于有限状态机与消息队列的三方支付系统补单实践

Java架构师迁哥

S型曲线不止关乎身材?|技术人应知的创新思维模型(2)

Alan

创新 思维模型

第六周-学习总结

Mr_No爱学习

生产环境压测建设历程之三 淘宝网2009年的痛

数列科技杨德华

《卫报》优化了移动推送通知投递架构_云原生_Rafal Gancarz_InfoQ精选文章