本章节介绍 Rspack 中一些常见的性能瓶颈和性能分析方法。
尽管 Rspack 本身提供的构建性能已经足够优秀,但在 Rspack 中使用一些 JavaScript 编写的 loaders 和 plugins 时,它们可能会导致整体的构建性能劣化,尤其是在大型项目中。
对于这类问题,有一部分可以通过 Rspack 内置的高性能替代方案来解决,另一部分可以通过性能分析工具来定位,从而采取针对性的优化。
下面是一些常见的案例:
babel-loader 基于 Babel 来编译 JavaScript 和 TypeScript 代码,可以将 Babel 替换为更快的 SWC。Rspack 内置了 builtin:swc-loader,它是 swc-loader
的 Rust 版本,旨在提供更优的性能。
如果你需要使用 Babel 插件实现自定义的转换逻辑,可以在配置 babel-loader 时使用 Rule.include 来匹配尽可能少的文件,以减少 Babel 编译的开销。
postcss-loader 基于 PostCSS 来编译 CSS 代码,通常会配合 PostCSS 插件进行 CSS 语法降级、添加浏览器前缀等,可以将 PostCSS 替换为更快的 Lightning CSS,使用 Rspack 内置的 builtin:lightningcss-loader 即可。
如果项目里使用了 Tailwind CSS v3 的 PostCSS 插件,则需要等待 Tailwind CSS v4 版本发布,该版本基于 Rust 和 Lightning CSS 实现,性能会有显著提升,详见 Open-sourcing our progress on Tailwind CSS v4.0。
terser-webpack-plugin 基于 Terser 来压缩 JavaScript 代码,可以将 Terser 替换为更快的 SWC minimizer,使用 Rspack 内置的 SwcJsMinimizerRspackPlugin 即可。
css-minimizer-webpack-plugin 基于 cssnano 等压缩工具来压缩 CSS 代码,可以将 cssnano 替换为更快的 Lightning CSS minimizer,使用 Rspack 内置的 LightningCssMinimizerRspackPlugin 即可。
less-loader 基于 Less 来编译 .less
文件,由于 Less 目前没有官方实现的高性能替代方案,建议使用 sass-loader 和 sass-embedded 代替,sass-embedded 是 Sass 原生 Dart 可执行文件的 JavaScript wrapper,具备出色的性能。
html-webpack-plugin 在生成大量 HTML 文件时,性能表现不佳,Rspack 基于 Rust 实现的 HtmlRspackPlugin 可以提供更好的性能。
Rspack CLI 支持使用 RSPACK_PROFILE
环境变量来进行构建性能分析。
执行该命令后会在当前目录下生成一个 .rspack-profile-${timestamp}-${pid}
文件夹,该文件夹下会包含 logging.json
、trace.json
和 jscpuprofile.json
三个文件
trace.json
:使用 tracing 细粒度地记录了 Rust 侧各个阶段的耗时,可以使用 ui.perfetto.dev 进行查看jscpuprofile.json
:使用 Node.js inspector 细粒度地记录了 JavaScript 侧的各个阶段的耗时,可以使用 speedscope.app 进行查看logging.json
:包含一些日志信息,粗粒度地记录了构建的各个阶段耗时你可以通过使用 Rsdoctor 来查看 Loader 和 Plugin 的编译耗时及编译过程。
如果想要分析 Loader 和 Plugin 耗时或者 Loader 的编译行为,可以利用 Rsdoctor 来查看:
您可以在时间轴中查看每个 Loader 的执行时间以及编译的文件,以及这个 Loader 编译文件所花费的时间。
参考 Loader Timeline.
如果你想查看 Loader 对代码编译过程,那么可以利用 Loader Details 功能:
在这个报告页面中,你可以查看到 Loader 对每个文件的编译前后的代码的变化。
参考 Loader Details.
关于如何启用 RsdoctorRspackPlugin
,可以参考 使用 Rsdoctor。
RsdoctorRspackPlugin
的 features.loader
和 features.plugins
参数需要为 true
,features.loader
和 features.plugins
是默认开启的。查看参数文档Rsdoctor options。