Webpack缓存失效?一文搞定排查难题!

背景

由于项目构建比较耗时,因此想到启用webpack持久化缓存来提升二次构建速度

webpack persistent cache设置

设置了缓存类型为 'filesystem',并且指定当 webpack 配置文件发生变化时,缓存失效。这样,如果配置文件发生变化,Webpack 就会重新构建所有的模块,以确保构建结果的正确性

js 复制代码
module.exports = {  
  //...  
  cache: {  
    type: 'filesystem', // 缓存类型,默认是 'filesystem'  
    buildDependencies: {  
      config: [__filename], // 当 webpack 配置文件发生变化时,缓存失效  
    },  
  },  
  //...  
};

遇到的问题

底层是使用create-react-appreact-scripts,但是设置缓存后,一直无法生成缓存文件,同时缓存也未生效

缓存不生效的原因:compiler.run之后,没有执行compiler.close

create-react-app相关问题issues:

webpack相关说明:webpack.js.org/api/node/#r...

Don't forget to close the compiler, so that low-priority work (like persistent caching) have the opportunity to complete.

如何查看缓存是否生效:开启webpack构建logger功能(infrastructureLogging.debug = true;

webpack相关说明文档:webpack.js.org/configurati...

  • 二次构建速度明显变快(整个来说),看到下面的日志,即可看到缓存开始生效。

[webpack.cache.PackFileCacheStrategy] starting to restore cache content

其它问题:

  • thread-loader跟webpack cache 兼容性问题,第2次以及后续构建时,构建快结束时,progress会block掉,初步推测是多线程和compiler之间协调有问题(暂未解决
  • mini-css-extract-plugin跟缓存不兼容,可能是有css问题

相关问题issue:github.com/webpack/web...

解决方案

修改react-scripts的build文件,在里面添加类似的实现代码,因此需要修改node端require相关逻辑,使得require('react-scripts/scripts/build') 指向我们的期望的build文件,该build文件是react-scripts build文件的加强(魔改 )版本

存在的风险

修改了 react-scripts的文件,后续升级的时候需要注意变更

相关推荐
哀木1 小时前
一个简单的套壳方案,就能让你的 Agent 少做重复初始化
前端
问心无愧05131 小时前
ctf show web入门27
前端
小村儿1 小时前
给 AI Agent 装上"长期记忆":Karpathy 的 LLM Wiki 思想,我做成了工具
前端·后端·ai编程
竹林8181 小时前
用ethers.js连接MetaMask实现Web3钱包登录:从踩坑到稳定运行的完整记录
前端·javascript
heyCHEEMS1 小时前
如何用 Recast 实现静态配置文件源码级读写
前端·node.js
心连欣1 小时前
从零开始,学习所有指令!
前端·javascript·vue.js
review445432 小时前
大模型和function calling分别是如何工作的
前端
东东同学2 小时前
耗时一个月,我把 Nuxt 首屏性能排障经验做成了一个 AI Skill
前端·agent
冴羽3 小时前
超越 Vibe Coding —— AI 辅助编程指南
前端·ai编程·vibecoding
梦想的颜色3 小时前
一天一个SKILL——前端最佳自动化测试 webapp-testing
前端·web app