注册会员
×

已有账号? 请点击

使用其他方式登录

Turbopack构建工具比Webpack快700倍,比Vite快10倍

发布2023-06-07 浏览643次

详情内容

Turbopack构建在新的增量架构之上,能以非常快的速度打包应用程序,特别是针对大型应用程序,更新速度是前端工具Vite的10倍,而且比Webpack还要快700倍,官方提到,越大的应用程序速度差异越大,甚至可以比Vite快20倍。


Turbopack只会捆绑最少所需的开发资源,因此启动速度非常快,在具有3,000个模块的应用程序,Turbopack只需要1.8秒就能完成启动,而Vite需要11.4秒。官方披露Turbopack快速的原因,Vercel参考Turborepo和Google Bazel的开发经验,通过缓存来避免重复执行相同工作。


webpack 核心开发者 @wSokra 加入 vercel 后的大招,Turbopack 完全可以挑战且远超过Webpack和Vite。Vercel 的使命是提供代码创造者在灵感迸发瞬间所需的速度和可靠性。去年,我们专注于提升 Next.js 打包 App 的速度。

每次我们从基于 JavaScript 的工具转移到基于 Rust 的工具时,我们都能看到巨大的改进。我们迁移了 Babel,提升了 17 倍的速度。我们替换了 Terser,压缩的速度提高了 6 倍,从而减少了加载时间和带宽的使用。

image.png

还有一个障碍:Webpack。Webpack 已被下载超过 30 亿次。它已经成为构建 Web 的不可分割的一部分,但现在是时候加速,无限制扩展了!


今天,我们推出Turbopack[1]:Webpack 的接班人。

image.png

Turbopack 有多快

Turbopack 建立在新的增量体系结构上,以获得最快的开发体验。在大型应用中,它展示出了 10 倍于 Vite 的速度,700 倍于 Webpack 的速度。在更大的应用中,差异更加巨大 —— 通常比 Vite 快 20 倍。


Turbopack 在开发环境只打包需要的最小资产,所以启动飞快。在一个 3000 个模块的应用里,Turbopack 只花了 1.8 秒启动,Vite 花了 11.4 秒。

image.png

什么 Turbopack 这么快?

Turbopack 的架构吸取了 Turborepo 和 Google 的 Bazel 等工具的经验教训,两个工具都专注于使用缓存,永远不会重复相同的工作。

Turbopack 是建立在 Turbo 之上的,Turbo 是基于 Rust 的开源、增量记忆化框架。Turbo 可以缓存程序中任何函数的结果。当程序再次运行时,函数将不会重新运行,除非它的参数改变了。这种粒度的架构使您的程序能够在函数级别跳过大量工作。

增量响应式系统,又有 Rust 的速度加持?Turbopack 是不可阻挡的!

在 Turbo 的讲解[3]里学习更多。

Turbo 的未来

首先,Turbopack 将用于 Next.js 的开发服务器。它将为闪电般快速的 HMR 提供动力,并天然支持 React Server Component,Typescript,JSX,CSS 等也一样。

Turbopack 最终也会赋能 Next.js 的生产环境构建,无论是本地还是云端。我们会在你的整个团队里共享 Turbo 的缓存,用Vercel Remote Caching[4]。

Webpack 用户还可以期望未来可以增量迁移到 Rust-based 的 Turbopack 特性。

我们对 Turbo 生态系统的未来感到更加兴奋,我们推动它来帮助你更快速的迭代,在灵感到来时更好的创造。


点击QQ咨询
开通会员
返回顶部
×
  • 微信支付
  • 支付宝付款
微信扫码支付
微信扫码支付
请使用微信描二维码支付
×

提示信息

×

选择支付方式

  • 微信支付
  • 支付宝付款
确定支付下载