相比普通格式图片,纹理压缩可以节省大量显存和 CPU 解码时间,且对 GPU 友好。目前,NextRPC 已经在淘宝的部分交易场景上线,经历几次大促,业务模式稳定。
NextRPC 是对 RPC 请求模式的创新和探索,它可以像多级火箭一样,返回 Payload 多段数据,从不同的网络通道请求/应答多段返回,最终完成业务场景交付。里面的“Next”有双关的意思:
目前,NextRPC 已经在淘宝的部分交易场景上线,如:下单换购业务在2021年4月初上线,经历9.9、11.11两次大促,业务模式已经稳定。在2021年的双十一大促中,通过 NextRPC 链路给业务整体带来超过5%的 uv 转化提升,在多商品中选择一个最优商品透出的场景下,uv 转化提升达25%以上。
在一些交易核心链路如 购物车、订单 等场景,期望引入导购链路的推荐算法,基于店铺维度针对单品、多品SKU、跨店场景进行个性化推荐,推出如“顺手买一件”的个性化推荐产品或其他优惠信息的透出,提升uv转化率。
当 核心交易场景 遇上 个性化推荐 ,交易 和 导购 的场景碰撞,会产生以下新的问题:
上述的这些问题,引出了新的技术挑战:如何在一次请求中同时支持对「用户体验」、「服务质量」、「资源」要求不一样的多个业务支撑系统。
以下针对五种常见的RPC模型展开对比分析:
请求处理模型主要分析 串行处理、并行处理两种模型。
NextRPC结合了 单请求异步推送数据流 的RPC模式和 并行处理 的请求处理模型,解决了新的业务场景带来的挑战:
单请求异步推送数据流:
可以将 核心业务逻辑 和 非核心业务逻辑 解耦,保证核心数据同步响应,非核心数据异步响应,解决服务质量问题;
交易链路、导购链路逻辑解耦,内部跨应用调用,解决机器资源问题;
并行处理:
业务逻辑可并行化处理,节省串行等待时间,解决交易链路用户体验问题
1 . 副请求编排,一个主请求多个副响应的场景下,客户端如何知道总共有多少个副请求? 由于服务端业务调用 NextRPC SDK 发送副请求,SDK 是知道自己被调用了多少次的,所以这个信息由 SDK 来统计并存储,SDK 内部维护一个副请求元信息,包括总数、副请求业务信息,业务每调用一次 SDK 发送副请求,SDK 累加累加总数,主响应结束时,同时下发副请求总个数。
2 . 副请求处理,不同业务吞吐量不一样,多个业务之间如何隔离确保互不影响? 业务之间通过消息中间件的不同 Topic 或者 不同的 Tag 进行隔离,每个 Topic 或 Tag 使用单独线程池消费。
3 . 消息过期、重复如何处理? 副请求通过消息中间件发送,当副请求接收端收到消息时,消息存在过期、重复的情况,SDK 提供消息的元信息(包括时间戳、唯一标识)
消息过期:SDK 内部可
消息重复:需要由业务代码根据请求的唯一标识来实现幂等。
NextRPC作为一种单请求多响应的RPC模式,按请求阶段划分,衡量服务质量的技术指标可以分为 3 种:
不同的请求阶段会有不同的技术指标,可以用于客户端、服务端服务质量分析,各个阶段产出的指标如下图所示:
双11是阿里巴巴的超级工程,2021年是双11的第十三个年头,立足过去12年的技术与商业创新,是一个新轮回的开始。
我们从追求更高到追求更好,技术也在探索这个过程,围绕消费体验不降级这个目标,我们在核心交易链路上做出大胆的技术尝试,追求交易确定性和体验的同时,提供更好、更有质量的服务满足消费者,并且可以赋能商家提升运营能力。
后续,我们也将继续尝试落地更多业务场景,借助NextRPC为业务的创新助力!
Copyright© 2013-2020
All Rights Reserved 京ICP备2023019179号-8