简介:随着 Serverless 在业界各云平台落地,阿里内部 Serverless 研发平台、各种研发模式也在业务中逐步落地,如火如荼。在此契机下,淘系团队启动了轻店 Serverless 研发模式升级战役,基于阿里集团底层设施建设、上层技术体系,解决在淘系轻店业务场景下碰到的系列问题,并借此推动现有前后端协作模式转变。

一、前言

随着 Serverless 在业界各云平台落地,阿里内部 Serverless 研发平台、各种研发模式也在业务中逐步落地,如火如荼。在此契机下,淘系团队启动了轻店 Serverless 研发模式升级战役,基于阿里集团底层设施建设、上层技术体系,解决在淘系轻店业务场景下碰到的系列问题,并借此推动现有前后端协作模式转变。

二、背景

轻店业务是淘系新型业务,目前处于探索试错阶段,如何能以较低人力成本配合业务快速试错,是团队当前需要考虑的问题。Serverless 重要的特点之一“only focus your business”。因此,拥抱 Serverless,轻店业务势在必行。本篇主要介绍,Serverless 技术在轻店前端团队如何落地,以及如何推动轻店研发模式升级,提升研发效率。在此基础上,同时探索前端职能转变成为应用开发的可能性。

三、研发模式升级

本文首先调研阿里集团内外 Serverless 现状,结合自身业务特点做技术选型;随后在轻店域内进行业务落地,在落地过程中逐步落实以下能力:以 sidecar&bottle 作为底层支撑,以一体化研发模式结合公共服务层、原子能力层、基础 SDK 来提升研发效率;最后通过轻店标准研发链路来保障业务稳定性;最终形成轻店 FaaS 体系,初步实现研发模式提效升级。

1. 技术现状

阿里集团各 BU 过去一年里在 Serverless 领域做了很多工作,主要集中在基础建设、研发模式、逻辑编排、稳定性建设、以及将 faas 链路打通并落地到 B 侧和 C 侧业务场景,如下图所示。各业务依赖的 Serverless 平台集中在 C 平台 / F 平台(PS:阿里内部 Serverless 平台)。

2. 技术选型

当前阿里集团 Serverless 平台和 midway-faas 团队深度合作,定制了基于阿拉丁 FaaS 方案,依托袋鼠为业务网关,承载请求分发的职责,并且有容灾、兜底等通用能力。袋鼠以天马体系(PS:指以统一模块规范为基础的搭建体系)为基础底座,但是轻店业务底层依赖装修体系。因此,我们需要重新选型实现基于轻店场景的 faas 解决方案。除此之外,轻店业务核心依赖各种中台服务。这些中台服务大部分是以富客户端(PS:指集成了本地能力的二方包)形式提供,如何在 nodeFaaS 体系中使用富客户端,是我们技术方案需要考虑的重点。下面是 C 平台方案(PS:阿里内部的 Serverless 平台) 和 G 平台方案(PS:阿里内部的 Serverless 平台)的链路对比图。

其中, G 平台链路有 bottle 能力提供富客户端方案,整体系统链路层级少,性能更优,因此我们最终技术选型为 G 平台。作为业务方,和各平台一起推动&打通 G 平台方案在前端 FaaS 场景落地。

3. 轻店 FaaS 体系

随着业务落地,能力沉淀,轻店 FaaS 逐成体系。

轻店 FaaS(代号:玳瑁),有基础能力层,包含接口聚合、数据映射、函数兜底、灰度等。原子服务层,沉淀了轻店业务场景的各种中台能力封装,上层提供基础 SDK,将各种能力直接给到业务使用。轻店 FaaS 在业务落地时,和前端模块组成轻店的商业 SaaS 能力,通过解决方案将商业能力组合,服务轻店各种业务场景。

1)SideCar & bottle

轻店业务核心依赖中台和中间件能力。因此,首先要解决的问题是,在 nodeFaaS 技术体系下如何调用富客户端和中间件能力。

轻店与 G 平台、midway FaaS 团队一起推进基于 G 平台开发 node FaaS 能力。G serverless 平台中,一个 pod 上面有两个容器,sidecar 容器主要负责请求发现、分发、协议解析、提供各种服务能力(中间件、中台服务);function 容器运行 node runtime 并且在上面跑业务 faas 代码。容器之间通过 GRPC 进行通信。最终,业务代码可以通过 bottle-SDK 调用富客户端/中间件能力。如下图所示:

基于上述方案,轻店 FaaS 实现了满足轻店业务场景的能力图谱。中间件层面主要集中在消息队列(metaQ)、运维(switch、diamond)、服务(HSF、mtop、http)、缓存(tair、redis)、数据库(云 RDS)、调度(schedulerx)等。中台能力集中在商品、商户、门店、券、标、店铺、UIC 等。随着业务发展,在逐步丰富中。

2)玳瑁 FaaS 能力

玳瑁在运行态,以 G 平台和 node rutime 为底层平台,通过原子层能力实现业务 Faas 函数,并在公共层统一提供数据聚合、兜底等能力。在研发态,基于统一研发平台和小程序端实现轻店一体化研发链路,包含统一构建发布流程、UI 配置化映射、FaaS 函数自动补全等。如下图所示:

公共层

api 请求过来,首先经过公共层(代号:羚羊)。公共层主要实现了轻店域内的基础通用能力。比如,自定义投放能力、兜底能力、聚合能力、配置能力。其中:

  • 自定义投放能力是打通了阿X丁(PS:阿X丁指阿里集团内部通用投放平台),业务可以自定义配置定投规则项,比如按商家、人群、区域、业务维度定投数据;
  • 兜底能力,针对需要保障高可用的 C 端接口,即使接口挂了也可以通过备份数据进行兜底,让消费者对服务异常无感知;
  • 聚合能力是将轻店页面装修数据和模块内部数据统一下发,提高页面性能,防止页面抖动。并且基于统一下发服务的基础上,实现页面级别、接口级别的兜底,模块插件灰度能力。

原子能力层

原子能力层,是沉淀轻店业务场景的各种中台能力封装(门店模型、商品模型、券模型……)。基于这些原子能力,轻店 FaaS 统一收敛外部依赖,业务可以减少外部对接成本,实现业务功能,同时也为映射补全能力提供基础。

FaaS-SDK

为了提升效率,轻店抽象出 FaaS-SDK,包含各平台适配、缓存能力、日志规范、锁能力、数据库封装、通用工具等等。其中:

  • 平台场景的适配包含阿里集团内各 Severless 平台,让开发者对平台无感知,只需要关注业务逻辑本身;
  • 轻店体系下提供多级缓存能力,对 RT 要求高的高可用场景,提供技术支撑;
  • 通用日志规范,对 FaaS 场景的 INFO、ERROR 日志进行格式规范,并封装成独立包供业务使用。

一体化研发模式

在公共层能力层、原子层能力、SDK 、以及 sidecar & bottle 的基础上,我们打通小程序模块和 FaaS 研发链路,实现轻店一体化研发模式。

一体化研发模式是指,基于端开发小程序模块,同时在同一个项目中实现 FaaS 能力。在前端代码中直接引用 FaaS 代码作为函数调用,无需通过请求调用;并且在整个研发链路中,实现两端同步创建&发布。在轻店场景下,这种研发模式节省了前后端沟通联调成本,大大提升研发效率。

稳定性

最后,为了保障业务的可靠性和稳定性,轻店定义了轻店 FaaS 的标准研发链路。从研发生命周期(研发态、待上线、上线中、上线后)各个阶段配置不同的措施来保障业务稳定性。如下图所示:

至此,轻店 FaaS 体系已介绍完,以 sidecar 支撑底层能力,一体化研发模式结合公共服务层、原子能力层、基础 SDK 来提升研发效率,最后通过标准研发链路来保障稳定性。

通过轻店 FaaS 体系支撑轻店业务,前端从前到后 cover 完整业务,后端同学更聚焦在业务中台能力建设。前端职能逐步转变,从前端到全栈,从资源到业务合伙人。对整体业务而言,以更少的协同沟通成本,更少的联调成本,让团队整体效率提升。自此,轻店团队初步实现研发模式升级。

4. 业务落地现状

当前淘系轻店 FaaS,已在多个轻店域内业务落地。

四、未来

未来,淘系团队将继续在轻店 faas 体系的基础上,探索一体化研发模式的最佳提效实践。

活动推荐

2021 年,Serverless 来啦!4 月 24 日(周六),阿里云 Serverless Developer Meetup 即将亮相上海。我们邀请了来自阿里云、飞猪、高德的技术专家,共同探讨过去一年 Serverless 在实际生产中待解决问题及优秀经验,披露 Serverless 在高德、飞猪以及其他企业的实战过程,详述 Serverless Devs 2.0,如何更有效解决 Serverless 应用开发的痛点。戳我立即报名!

原文链接:https://developer.aliyun.com/article/783687?

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

手机淘宝轻店业务 Serverless 研发模式升级实践相关推荐

  1. 手机淘宝短视频业务「哇哦视频」迁移上 FaaS 笔记公开

    导读:2019 年,在阿里巴巴集团内部技术论坛上对于 Serverless 和 FaaS 的讨论非常火热. 限时福利:张磊.李响等人撰写的 <CNCF X 阿里巴巴云原生技术公开课> 限时 ...

  2. 【阿里技术沙龙】打造手机淘宝开放业务生态

    1沙龙主题 随移动互联网快速发展,拥有亿级活跃用户.千万级卖家资源的手机淘宝,基于无线技术致力于为开发者提供一个稳定.开放的移动电商业务平台,携手三方开发者一起创建"开放,创新,共赢&quo ...

  3. 牛店网:手机淘宝淘友圈是什么?怎么开启?

    我们在淘宝上不仅可以购买很多物美价廉的商品,还可以把自己喜欢的商品分享给朋友,朋友拍下了,大家就能赚钱了.那么手机淘宝淘友圈怎么开启?下面给大家讲述一下. 手机淘宝淘友圈是什么意思? 淘友圈就是淘宝新 ...

  4. 当手机淘宝遇见海尔电商

    该文章来自阿里巴巴技术协会(ATA)精选集 7月的青岛,向来是旅游胜地.手机淘宝技术团队收到海尔的邀请,展开了一场别开生面的技术之旅,阿里无线事业部(手机淘宝)资深总监南天也应邀在[海尔电商技术沙龙] ...

  5. 手机淘宝客户端架构探索实践

    宗心:淘宝无线事业部资深开发工程师,手机淘宝iOS架构组开发工程师,2012年底参与开发手机淘宝iOS3.0版本,经历大小几十个版本的变迁,针对手机淘宝总体设计架构,hybrid框架解决方案,插件化解 ...

  6. 手机淘宝构架演化实践及优化,天猫,淘宝服务

    > 天猫App 安全模式:天猫App启动保护实践- https://mp.weixin.qq.com/s?__biz=MzUxMzcxMzE5Ng==&mid=2247488429&am ...

  7. 手机淘宝的客户端架构探索之路

    本文转自:http://blog.csdn.net/licaomengrice/article/details/49253255 主讲人:冯森林(无锋/ Oasis Feng) 产品挑战 淘宝手机客户 ...

  8. 手机淘宝:亿级用户APP的快速运维交付实践

    作者简介: 倪生华 淘宝网  资深技术专家 花名玄黎,12年加入淘宝无线事业部,经历了手淘从几十万日活到现在亿级日活的过程,一直负责手淘端研发运维等工程效率相关的工作,团队负责开发的支撑体系,很好的解 ...

  9. 手机淘宝 521 性能优化项目揭秘

    http://www.infoq.com/cn/articles/mobile-taobao-521-performance-optimization-project 又是一年双十一,亿万用户都会在这 ...

最新文章

  1. 后退N帧协议-GBN
  2. WIN7 64位系统搭建WINCE6.0系统遇到的问题
  3. SAP CRM WebClient UI上将text area里的文本清空的后台处理
  4. python和php互动_PHP中常见的五种设计模式
  5. hey 安装_如何在助理扬声器上调整“ Hey Google”的灵敏度
  6. 关于增强学习你应该了解的五件事儿
  7. python如何将图片打包进exe里_用python将图片切分为九宫格 并打包成exe可执行文件(附源码)...
  8. C#笔记03 运算符和分支结构
  9. python遇到‘\u’开头的unicode编码
  10. python并发编程 协程_Python并发编程协程之Gevent
  11. 非常经典的java编程题全集-共50题(11-30)
  12. 三种教鞭工具使用对比
  13. python pycharm 书籍_有什么Python学习的书籍和学习资源推荐?
  14. 服务器pbs傻瓜操作
  15. 微信小程序新手教程 1.0
  16. 面试官:你在平时的工作中遇到过哪些问题让你印象深刻?
  17. c51单片机扩展64K的RAM
  18. 软件质量(ISO/IEC 9126)的定义与特性
  19. 移动端开发——APP端上H5容器化建设
  20. 探寻软件的永恒之道 ——评介《建筑的永恒之道》 - 撰文/透明

热门文章

  1. HDFS API编程之副本系数
  2. 用CSS美化被鼠标选中的文字的样式
  3. 瞧瞧,这样的『函数』才叫 Pythonic
  4. 一个没法商用,但是好玩有趣的 Python 手绘图形库!
  5. php 链接excel表格数据,php 怎么把数据导出到excel表格?php 连接 excel表格数据库数据...
  6. java加载并运行虚拟机_《深入理解Java虚拟机》- Java虚拟机是如何加载Java类的?...
  7. PyTorch基础-线性回归以及非线性回归-02
  8. [PHP] 现代化PHP之路:composer的镜像站设置
  9. CodeForces 906D (欧拉降幂)
  10. js条件语句初步练习