一文带你揭秘淘宝终端技术

一文带你揭秘淘宝终端技术

作者:周杰(寻弦)

在这个数字化迅速发展的时代,技术的每一次飞跃都不仅仅意味着一个产品的升级,更是对未来世界的一次大胆想象。从 PC 到 iPhone,从 Model 3 到 ChatGPT,都引领了全新的一个行业。对于正处在求学阶段的你们,选择一个充满活力、技术领先、并且可以提供巨大成长空间的团队,无疑是迈向成功职业生涯的关键第一步。现在,就让我们一同揭开淘天终端技术团队的神秘面纱,一步步为你揭晓为何我们在终端技术领域独树一帜。

一、终端技术体系和代表作

我们团队主要负责的是淘宝——这个星球上最复杂的 App(没有之一)的基础设施,数以亿计的用户在这个 App 上浏览商品/查看详情/买卖家交流/下单购物/互动娱乐/消费内容等等,任何单一功能的复杂度都可以媲美市场上的一个独立 App,把所有这些都聚合在一个巨型 App 中,我们面临的是几大核心矛盾:有限的包体和设备存储空间 vs 无限增长的业务模块、有限的终端硬件资源 vs 无限叠加的业务场景、有限的设备能耗 vs 不断沉浸的体验追求、碎片化的海量设备 vs 统一化的交付方式等等。

举几个实际的例子:

淘宝里的业务模块成百上千,而淘宝 Android 端的包大小居然回到了 18 年的水位(65M),处于行业前列。每天有大几亿用户打开淘宝 App,这些用户在淘宝上的行为非常多样化。

  • 有些用户喜欢搜,他们目的性很强,直接搜索商品关键字-进入商品详情查看和比价-下单;

  • 有些用户喜欢逛,在首页信息流和 ND 来回浏览-进入商详查看-加购或下单;

  • 有些用户喜欢玩,在我的淘宝中玩些小游戏-查看商品/店铺-可能加购或下单;

  • 有些用户喜欢看,在 Tab2 看视频(可赚钱)-查看视频中提到的感兴趣的商品-可能加购或下单等。

我们要保障用户在每条可能的路径和动线上都有着丝滑的体验,这是世界级的技术难度和挑战!

现在国人的日常衣食住行都已经离不开手机了,而其电池技术并没有根本性的突破,如何既能解决用户的续航焦虑,又能提供优雅的用户体验,以及使用过程中不出现发烫/卡顿,这是操作系统级别的技术难题和挑战!

为了应对和解决这些技术挑战和难题,我们长期探索这几大技术方向:

  • 原生技术,遵循 Platform First 理念,贴近原生系统、充分挖掘系统组件和特性,沉淀极致性能的渲染引擎/动态化引擎/原子能力集,同时与厂商深度合作,探索站内外用户触达多通道,用技术做用增;

  • 底层技术,遵循 First Principle 理念,深入虚拟机/字节码/汇编指令等,探索稳定性/性能/包体的极致边界,深入系统底层机制与原理,必要时帮系统打补丁;

  • 跨端技术,遵循 Cross Platform 理念,抹平多系统/平台差异,充分利用业界较为成熟的前端生态,沉淀自主可控的渲染引擎/图形引擎/脚本引擎,向业务提供符合 W3C 标准的前端友好的基础设施;

  • 工程技术,遵循 Productivity First 理念,支撑大规模多团队协作式研发,深挖工程组织/编译构建/虚拟机调度等技术,融合前端/客户端研发工作流,向业务提供高效稳定的工程体系;同时持续升级 Low Code 技术,赋能业务运营同学快速搭建页面上线,实现产品运营需求的想发就发;

  • 网络技术,拥抱网络协议新标准,重点优化移动弱网场景,以更小带宽,实现更快的传输,面对复杂移动场景,提供弹性可伸缩的网络服务,平衡前后台的业务体验;

  • 应用服务技术,遵循 API First 理念,解决接口大规模稳定快速投放,扩展丰富的请求模式/传输协议/压缩算法等,探索端云交互一体化新模式和端云研发新模式;

  • AI 技术,依托于大模型近来的突飞猛进,我们承担着进一步提升淘宝业务研发效率和体验的使命,包括多模态代码生成(一句话需求生成逻辑代码/一张视觉稿生成 UI 代码/基于一段真实代码生成单测代码)、问题诊断(线上 Crash 诊断/端到端问题自动定位/构建失败诊断/场景化性能诊断调优)、研发助理(领域知识答疑/最佳实践问答)等等。

每个技术方向我们都有着多年的辛勤打磨和持续沉淀,历经了多年线上大规模用户和流量的千锤百炼,以下是我们的部分代表作:

  • 原生动态化技术:基于 play core 的动态化方案,具备了 Replugin(360)和 Qigsaw(iQiyi)合并的优势,既支持插件化,又支持组件动态化;

  • 原生研发框架 DX 4.0,以 Kotlin+Compose 为标准,声明式/响应式/状态管理/一码多屏为特性,基于原生系统 UIKit 构建原生渲染管线、基于 KMP 构建面向多平台的编译体系,支持原生组件和能力的快速定制和扩展;

  • 自绘渲染引擎 Weex 2.0,自建符合 Web 标准的自绘渲染引擎,包含执行代码/节点构建/布局/绘制/合成/光栅化/上屏等完整渲染管线;建立字节码离线编译的工程体系,编译期可进行耗时更高更彻底的优化,并支持标准 ESM 模块、多文件拼接、动态执行脚本、模块搭建等能力;弹性可扩展的容器和插件能力,支持全页/浮层/卡片/小部件/Embed 等多种形态及插件;

  • 流式 SSR 技术,业界率先尝试零运维流式 SSR 托管服务,简化流式 SSR 页面研发成本,相对业内中心化 SSR 渲染方案,引入了 CDN ER 的边缘能力,降低客户端渲染压力,并实现就近的渲染快照,实现极致的 FCP 时间;

  • LSM 对象存储技术,业界腾迅开源的 MMKV、mongodb 的子项目 realm 都是针对移动端的对象/键值存储方案,分别使用了 MVCC 等存储模型用于提升高并发场景的性能,但没有针对 Flash 存储(SSD/UFS/)特性的优化。sqlite 的 btree 模型对大对象键值存储的读写放大系数较高。我们针对 Flash 存储特性(块读写机制、垃圾回收机制等)实现的 LSM Tree,支持了内存压缩、冷热分区、碎片化抑制等特性,在读写放大系数和吞吐性能上有显著优势,大量应用在移动端上图片及小文件缓存等场景;

  • 终端 APP 到全链路的观测与性能技术,立足 Android/iOS 原生特性提供 APP 维度的观测套件,以及各类 APP 高性能框架、组件,实现端性能持续优化与业务迭代;立足 OpenTelemetry 提供终端访问云上服务的全链路分布式技术规范与观测套件,实现终端 RPC、远程配置、消息、大文件上传/下载等高性能中间件,支撑业务链路优化与治理;

  • 终端工程构建技术,以流水线为主要支撑,通过灵活的配置插件形成统一的构建流水线,我们沉淀了终端丰富的工程构建工具链,支持 iOS/Android/PC/IOT 等多终端的自定义,同时结合私有化部署能够完全开放定制整个工程构建生产链路;

  • 高性能网络技术,在 IETF 国际标准组织,主导 Multipath-QUIC 协议标准化进程(作为协议第一作者);有 4 篇网络领域顶级学术会议论文和期刊收录,包括网络学术 Top1 顶会 SIGCOMM 21 发表论文<XLINK>/顶会 NSDI 收录<TECC>等;开源国内首个标准化协议库 XQUIC(git star 1.5K)/开源高性能云原生网关 Tengine(git star 12.2K);网络领域专利授权超过 20 个以上。

面向未来,在应用底座层我们会坚持系统+自研结合的方式,向下深挖系统内核,向上提供丰富稳定、抹平平台差异的系统能力;容器引擎层我们会坚持原生+跨端结合的方式,既要极致体验,又要快速交付,充分利用客户端和前端生态;工程支撑侧我们会坚持融合客户端+前端研发动线,支持业务高效研发和低成本运维,支撑淘宝成为全球最小最快最稳最爽的 App。

二、终端技术的团队和背后的人

技术代表作的持续演进和长期技术方向的持续探索,离不开背后的优秀工程师们,以及能持续培养出优秀工程师的土壤——团队。

我们团队倡导工程师文化,它不仅仅是一个口号,而是我们文化的核心。我们鼓励团队成员积极思考,敢于提出大胆的想法,打破现状,并为这些想法提供足够的支持与资源。

我们相信,工程师文化的核心,离不开一群优秀的技术牛人们,他们在各自技术领域拥有丰富的实践经验、较高的理论造诣,他们将成为你们的技术导师,带领你们一起成长,让你们可以引领潮流,创造未来。

技术牛人们的代表作品让人倍感震撼。他们参与制定了国际网络标准,比如【IETF】Multipath Extension for QUIC,这是一个先进性技术的行动和举措,改变了网络传输的方式,让网络更加高效和稳定。同时,他们也为 JavaScript 标准【TC39】做出了巨大贡献,完成 JS 语言特性提案两个,推出了 ShadowRealm、Async Context 和 Error Cause 等创新方案标准,为开发者们提供更加便捷和强大的工具,也为 CNCF OpenTelemetry JS 语言实现 Champion 和规范作出了贡献。

技术牛人们不仅在行业标准有着卓越的表现,他们的学术论文期刊发表也令人瞩目。比如【NSDI 2024】的 TECC,这是一项关于 QUIC 隧道技术的研究,致力于提高 QUIC 传输的效率和性能;还有【Computer Networks 2022】的 BBRv2+,一项关于带宽探测的研究,旨在实现对带宽的平衡和公平;以及【TNNLS 2023】的 Noah,这是一项关于强化学习的研究,为大规模电子商务服务中的微服务提供了智能的速率限制算法。

技术牛人们在开源社区也有着丰富的经验和贡献。他们开源了国内首个标准化协议库 XQUIC,这是一个备受关注的项目,已经获得 1.5K 个 star;同时,他们还为高性能云原生网关 Tengine(12.2K star)更新换代升级,成为了开源社区中的明星项目。

此外,我们的团队中有 Node.js TSC voting members(要知道一共才二十个核心成员)和 Google V8 committer,还推出了一系列基于 React 的应用研发框架,如 git star 达到 17.7K 的 ice.js,广受前端研发好评,以及 Node.js Serverless Framework 中的 midway.js,git star 达到 6.9K。还有 iOS 非侵入性能测试输出开源项目 tidevice,已经获得了 2K+个 star,广受开发者欢迎。

技术牛人们不仅有着卓越的技术实力,更重要的是他们乐于分享帮助他人

加入我们的团队,你将有机会与这些杰出的人才们面对面交流,让师兄师姐倾囊传授他们的经验和智慧。无论是在项目开发中遇到的问题还是职业规划上的困惑,团队都将为你提供指导和支持,帮助你成长为一个优秀的专业人才。

加入我们的团队,我们有定期的内部分享会、技术研讨和外部交流活动,让你能不断学习到新知识,拓宽见识,同时也鼓励参加国内外技术大会,与业界大咖面对面交流,从而激发更多灵感。

无图无真相,下面是我们最近的一些内外部分享的照片:

以及我们的团队全家福

三、未来展望

未来已来,终端技术的新纪元正在向我们招手。

未来的电商终端设备将通过高效的数据分析和智能学习,了解我们的习惯和偏好,为我们提供更精准的个性化服务。

未来的电商终端设备将通过先进的人机交互技术,如手势控制、面部识别、语音助手,我们可以以最自然的方式同设备进行交互,无需学习复杂的操作,为我们提供将更优雅的用户体验。

未来的电商终端设备将采用最新的加密方法和隐私保护措施,确保用户数据的安全不被侵犯。同时,终端设备将能够在本地处理更多的信息,减少对云端的依赖,从而在保障功能的同时,最大限度地保护用户隐私。

我们相信,未来的电商终端不再是冷冰冰的交易平台,而是一个充满人情味、智能互动、高度个性化的购物伙伴。随着科技的进步,未来的电商终端将彻底重塑我们的购物体验,将便利、乐趣和效率提升到前所未有的高度。

在我们团队的带领下,未来的终端技术正以我们的智慧和汗水孕育而生。我们不仅仅是技术的创造者和实践者,更是未来美好生活的梦想家。我们邀请每一位对技术抱有热情的伙伴,加入我们这个充满激情和创意的团队,一起憧憬并创造一个更加智能、安全、便捷的明天。

在此欢迎聪明靠谱的小伙伴加入(社招、校招、实习生、高校合作、访问学者等),简历请发至 leo.zhouj@taobao.com。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/328449.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux miniGUI移植分析

框架介绍 常用GUI程序对比 https://www.cnblogs.com/zyly/p/17378659.html MiniGUI分为底层的GAL&#xff08;图形抽象层&#xff09;和IAL&#xff08;输入抽象层&#xff09;&#xff0c;向上为基于标准POSIX接口中pthread库的Mini-Thread架构和基于Server/Client的Mini-L…

护眼灯有没有护眼的效果啊?有效果的护眼灯推荐

近几年&#xff0c;青少年近视人数呈现猛增的势头&#xff0c;且低龄化趋势也越来越明显&#xff0c;社会各界开始重视对青少年视力问题的关注。伤害视力的原因有很多种&#xff0c;其中没有良好的光线条件是问题之一&#xff0c;当使用的台灯不合格&#xff0c;频闪与蓝光问题…

渗透测试(12)- WireShark 网络数据包分析

目录 1、WireShack 简介 2、WireShark 基本使用方法 3、 WireShack 抓包分析 3.1 Hypertext Transfer Protocol (应用层) 3.2 Transmission Control Protocol (传输层) 3.3 Internet Protocol Version 4(网络层) 3.4 Ethernet Il (链路层): 数据链路层以太网头部信息 …

ZooKeeper 实战(五) Curator实现分布式锁

文章目录 ZooKeeper 实战(五) Curator实现分布式锁1.简介1.1.分布式锁概念1.2.Curator 分布式锁的实现方式1.3.分布式锁接口 2.准备工作3.分布式可重入锁3.1.锁对象3.2.非重入式抢占锁测试代码输出日志 3.3.重入式抢占锁测试代码输出日志 4.分布式非可重入锁4.1.锁对象4.2.重入…

数据结构之串|数组|广义表

串 数组 广义表 总结&#xff1a;

【JS逆向学习】1号店

逆向目标 接口&#xff1a;https://passport.yhd.com/publicPassport/login.do加密参数&#xff1a; credentials.usernamecredentials.password 逆向过程 老规矩&#xff0c;输入用户名和密码&#xff0c;点击登录&#xff0c;然后过滤 XHR 请求 进入 Initiator 随便找个…

计算机毕业设计------SSH新闻资讯网站管理系统

项目介绍 该系统分成两个项目&#xff0c;前台项目与后台项目&#xff0c;需要分别运行&#xff1b; 后台管理员角色包含以下功能&#xff1a; 管理员登录,新闻专题类别管理,友情链接管理,广告管理,新闻列表管理,管理员管理,信息修改等功能。 前台用户角色包含以下功能&#…

逸学Docker【java工程师基础】1.认识docker并且安装

场景问题 在实际开发过程中我们有这样的场景问题 在开发阶段的环境配置到了其他人项目人员那里就不能运行了&#xff0c;尽管配置规格相同&#xff0c;但是在较多的不同的环境情况下还是可能会有错误。 开发&#xff1a;程序员&#xff1a;你那边可以运行了吗 测试&#xf…

JUC的常见类

目录 Callable ReentrantLock Semaphore CountDownLatch JUC即 java.util.concurrent&#xff0c;其中存放了一些进行多线程编程时有用的类 Callable Callable是一个接口&#xff0c;在我们实现Runnable创建线程时&#xff0c;Runnable关注的是其过程&#xff0c;而不关注…

【1】SM4 CBC-MAC 机制

0x01 题目 MSG1: e55e3e24a3ae7797808fdca05a16ac15eb5fa2e6185c23a814a35ba32b4637c2 MAC1: 0712c867aa6ec7c1bb2b66312367b2c8 ----------------------------------------------------- MSG2: d8d94f33797e1f41cab9217793b2d0f02b93d46c2ead104dce4bfec453767719 MAC2: 4366…

【CF闯关练习】—— 1400分(C. Make Good、B. Applejack and Storages)

&#x1f30f;博客主页&#xff1a;PH_modest的博客主页 &#x1f6a9;当前专栏&#xff1a;cf闯关练习 &#x1f48c;其他专栏&#xff1a; &#x1f534;每日一题 &#x1f7e1; C跬步积累 &#x1f7e2; C语言跬步积累 &#x1f308;座右铭&#xff1a;广积粮&#xff0c;缓…

016-Vue-黑马2023:前后端分离开发(在线接口文档),前端工程化、Element、nginx

第三节 前后端分离开发 1、介绍 开发模式 前后端混合开发&#xff1a;传统开发模式 前后端分离开发&#xff1a;当前最为主流的开发模式 页面原型需求案例&#xff1a;分析出接口文档 离线开发文档示例&#xff1a; 2、YAPI&#xff08;官网已停用&#xff09; 202…

【工作记录】基于springboot3+springsecurity6实现多种登录方式(一)

前言 springboot3已经推出有一段时间了&#xff0c;近期公司里面的小项目使用的都是springboot3版本的&#xff0c;安全框架还是以springsecurity为主&#xff0c;毕竟亲生的。 本文针对基于springboot3和springsecurity实现用户登录认证访问以及异常处理做个记录总结&#x…

NVMe-oF RDMA vs. TCP延时测试对比:端到端SPDK的意义

前不久看到一篇《NVIDIA BlueField 再创 DPU 性能世界纪录》的新闻&#xff0c;该测试环境是2台服务器&#xff0c;每台各安装2块NVIDIA Bluefield-2 DPU&#xff0c;形成4条100GbE以太网直连&#xff0c;两端分别跑NVMe-oF Target&#xff08;存储目标&#xff09;和Initiator…

Spring IoC 和 DI

文章目录 1. 什么是 Spring2. 什么是 IoC3. 什么是 DI4. IoC & DI 使用5. 获取 Bean 的方式5.1 根据类型获取 bean5.2 根据名称获取 bean5.3 获取bean对象的其他方式5.4 五大注解的关联 6. 方法注解7. 扫描路径8. Bean 的名称9. DI 详解9.1 属性注入9.2 构造方法注入9.3 Se…

残差网络 ResNet

目录 1.1 ResNet 2.代码实现 1.1 ResNet 如上图函数的大小代表函数的复杂程度&#xff0c;星星代表最优解&#xff0c;可见加了更多层之后的预测比小模型的预测离真实最优解更远了&#xff0c; ResNet做的事情就是使得模型加深一定会使效果变好而不是变差。 2.代码实现 impo…

【OpenAI】自定义GPTs应用(GPT助手应用)及外部API接口请求

11月10日&#xff0c;OpenAI正式宣布向所有ChatGPT Plus用户开放GPTs功能 简而言之&#xff1a;GPT应用市场(简称GPTs, 全称GPT Store) Ps&#xff1a; 上图为首次进入时的页面&#xff0c;第一部分是自己创建的GPTs应用&#xff0c;下面是公开可以使用的GPTs应用 一、创建GPTs…

Spring Cloud 微服务中 gateway 网关如何设置健康检测端点

主要是为了让 k8s 识别到网关项目已经就绪&#xff0c;但是又不想在里面通过 Controller 实现。因为在 Controller 中这样做并不是最佳实践&#xff0c;因为 Gateway 的设计初衷是专注于路由和过滤&#xff0c;而不是业务逻辑的处理。 在 Gateway 中配置健康检查端点可以通过以…

单向不带头链表的使用

单向不带头链表的使用 链表的创建&#xff1a; typedef struct LNode {SLDataType data;struct LNode* next; }LNode,*LinkList; 按位查找 LNode* GetElem(LinkList L, int i) {int j 1;LNode* p L->next;if (i < 0)return NULL;if (i 0)return L;while (p &&…

4种方法用Python批量实现多Excel多Sheet合并

目录 方法一&#xff1a;使用pandas库 方法二&#xff1a;使用openpyxl库 方法三&#xff1a;使用xlrd和xlwt库 方法四&#xff1a;使用os和glob库 在数据处理中&#xff0c;经常需要将多个Excel文件中的多个工作表进行合并。以下介绍了4种方法&#xff0c;使用Python批量实…