QCon 演讲火热征集中,快来分享技术实践与洞见! 了解详情
写点什么

Netflix 的网站优化经验

  • 2015-08-10
  • 本文字数:1841 字

    阅读完需:约 6 分钟

服务端与客户端渲染

Netflix 团队首先要做的一件事是改进他们的整体前端架构。改版前的 netflix.com 网站对于服务端生成 html 标记与客户端的增强这两个过程进行了严格的分离,采用这一设计的主要原因在于前后端所使用的编程语言不同。服务端主要使用 Java 的技术栈以生成基本的 html 页面,而在浏览器端的工作则主要是通过 jQuery 等 JavaScript 库的使用为服务端生成的 html 添加一些客户端的行为。

这种分离式前端架构可以说是教科书一般的标准架构,但 Netflix 团队认为这种方式存在着一些不足之处,因为用户每次都需要等待服务端生成完整的 html 页面结构之后,才能够看到页面显示在浏览器中。这其中有很大一部分内容是用户很少会关注的,但仍然不得不为了加载这些内容延迟而延长页面的渲染时间。

因此,UI 工程团队专门针对这一点进行了全新的设计。改进后的服务端所生成的 html 只包含页面中的一小部分内容,使客户端的视图能够尽快地显示在用户眼前。为了了解用户对此改动的认可度,UI 团队将其设计为一种可配置的架构,可以非常方便地调整服务端所生成的 html 应当包含多少个视图。这种做法的好处很明显:首先是服务端生成的数据减少了,因此处理时间也相应地减少了。其次由于 http 的响应负载也减少了,DOM 的渲染时间也因此加快了速度。当页面完成渲染后,客户端 JavaScript 可以按需加载用户所感兴趣的其余视图。

UI 团体对此总结道,由于服务端与客户端渲染方式得到了更大的灵活性,为他们在这两种方式之间如何取得平衡提供了更多的选择。这一改动最终不仅使页面启动速度加快,同时也保证了平滑的视图转换过程。

通用 JavaScript

UI 团队的另一个目标是实现服务端与客户端代码的通用化,这就迫使他们重新思考整个渲染管道的设计。之前所采用的那种分离式服务端生成与客户端增强的做法已经难以满足他们的需求了,主要问题有以下三点:

  • 在两种编程语言之间来回切换是一种负担
  • 如果要对 html 进行改进,那么对于服务端的生成与客户端的增强都有着很强的依赖性
  • 团队更希望通过同一种 API 生成 html 标记

UI 团队最终选择了以 Node.js 与 React.js 实现一种通用 JavaScript 的前端架构,这使他们能够实现在服务端进行渲染,等基本的html 与React.js 组件完成初始化之后,再由客户端完成其它部分的渲染。因此,无论渲染过程是在哪里发生的,应用程序都能够得到相同的输出结果,服务端与客户端的代码也没有了严格的区分,它们全部是按照通用JavaScript 的方式设计的。也正是这种共通的渲染逻辑,让UI 团队意识到只在服务端进行最小化的html 渲染,由客户端完成其余部分加载这种方式的可行性。

减少JavaScript 负载

具有丰富交互性体验的网站通常需要用户下载大量的JavaScript 代码,这也一定程度上影响了浏览器的性能。为此,UI 团队在重构过程中将各种依赖转换为较小的模块,并只为当前访问者输出相应的JavaScript。关于如何实现这一过程的具体设计,来自Netflix 的高级前端工程师Alex Liu 专门在一篇文章中记录了具体的设计过程。

经过重构之后,老版本设计中的各种大型依赖已经不复存在,它们被替换为一些全新的、更高效的库。其直接结果就是输出的JavaScript 负载减少了许多,用户开始浏览时不再需要加载大量的JavaScript 代码。而UI 团队并不满足于当前的成果,他们还将不断地对JavaScript 的负载进行改进。

页面可交互时间

为了对重构后的效果进行测试,以更好地理解它对用户所产生的影响,UI 团队对于页面的可交互时间(Time to Interactive - tti)这项指标进行了专门的监控。

可交互时间是指从页面刚刚启动到用户能够与UI 进行交互的这一段时间间隔,这里并不需要完整地加载整个页面,只需要用户能够通过输入设备与UI 之间进行交互即可。

UI 团队建议使用由 W3C 定义的 Navigation Timing API ,在能够支持的浏览器上收集访问者的数据,并进行统计分析。

总结

在 Netflix 团队看来,高性能不是一种可有可无的目标,而是设计优秀的用户体验过程中必不可少的一环。团队将继续寻求业界的最佳实践,以实现更好的用户体验。在接下来的一段时间内,Netflix 将研究一些新兴的 web 标准,例如服务器线程(Service Workers)、 ASM.js 以及 WebAssembly 等等,看看这些技术能否帮助他们的网站性能更上一层楼。


感谢郭蕾对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群)。

2015-08-10 08:142937
用户头像

发布了 428 篇内容, 共 180.2 次阅读, 收获喜欢 39 次。

关注

评论

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

华为周智勇:“一切即一,一即一切”,加速优化智能企业数字治理

Geek_2d6073

科大讯飞 P20 Plus词典笔 测评

妙龙

科大讯飞 词典笔

国产游戏横扫全球、鸿蒙再度进化:中国游戏最好的时代真来了

最新动态

科大讯飞X3LAMY和X2LAMY区别

妙龙

科大讯飞 办公本

亮相AICon,火山引擎边缘云揭秘边缘AI Agent探索与实践

火山引擎边缘云

边缘计算 智能体 AI 大底座 边缘智能

鸿蒙生态以“新机遇、新体验、新服务”赋能游戏产业发展

最新动态

我的数字书库:华为阅读免费本地导入,让阅读更自由

最新动态

在线项目管理工具内网怎么用

爱吃小舅的鱼

在线项目管理工具

科大讯飞p30和s30的区别

妙龙

科大讯飞 学习机

2024-12-14:K 周期字符串需要的最少操作次数。用go语言,给定一个长度为n的字符串 word 和一个整数k,k是n的因数。每次操作可以选择两个下标i和j,使得i和j都可以被k整除,然后用从j

福大大架构师每日一题

福大大架构师每日一题

科大讯飞词典笔x8和x8pro选哪个好

妙龙

科大讯飞 词典笔

《Django 5 By Example》阅读笔记:p543-p550

codists

Python django

“明星级”人形机器人[波士顿动力]宣布裁员!

机器人头条

波士顿动力 特斯拉 人形机器人 具身智能

科大讯飞X8Pro和有道X7pro区别

妙龙

科大讯飞

苹果电脑可以玩《赛博朋克2077》吗?赛博朋克对苹果电脑的配置要求

阿拉灯神丁

赛博朋克 虚拟机软件 Mac游戏分享 苹果电脑游戏推荐 CrossOver 24

极越汽车倒闭员工惨,阿姨奶茶倒闭老板更惨,大龄失业程序员的出路在哪里?

陆通

微信native支付对接案例详解

恩爸编程

微信支付 微信支付开发 微信native支付对接

一文讲清数据库的分库分表

王中阳Go

数据库 后端

评测 科大讯飞T30Pro和LUMIE10Pro区别对比选哪个

妙龙

科大讯飞 学习机

拿到HUAWEI Mate70后,别忘了下载这个“新应用”

YG科技

出差用那个软件订票好报销?合思、易快报等主流平台对比

爱吃小舅的鱼

差旅平台

网易有道x6pro和科大讯飞p20plus哪个好

妙龙

科大讯飞

宋章明|工业数据管理模式变革驱动下,重新想象工业设备管理

麦杰研究院

科大讯飞翻译机4.0和SE、科大讯飞双屏翻译机区别对比

妙龙

科大讯飞 翻译机

科大讯飞T30Pro和T30Lite的区别对比评测

妙龙

科大讯飞 学习机

科大讯飞air2pro和x3区别

妙龙

科大讯飞 办公本

科大讯飞p20plus和s11区别

妙龙

科大讯飞

Netflix的网站优化经验_JavaScript_邵思华_InfoQ精选文章