Monorepo与pnpm最佳实践

本文将介绍如何使用 pnpm 及 Monorepo 实现高效的代码构建和发布流程。

什么是 Monorepo?

Monorepo 是一种将多个项目统一放在一个代码仓库中进行集中管理的方式,适用于项目间耦合度高、共享代码较多的场景

Vue 为例,其源码采用 Monorepo 管理模式,代码仓库中包含多个子项目,如 reactivityruntime-corecompiler-core 等。每个子项目拥有独立的 package.json,可单独安装、运行与测试。

这种管理方式带来的好处包括:

  • 便于团队协作:不同团队在同一代码库中开发,统一规范和流程,避免重复造轮子
  • 提升代码复用率:子项目间可以直接相互引用,无需通过发布依赖包的方式
  • 统一版本与质量控制:更易对各模块进行集中测试、构建与发布,保障整体代码质量
  • 降低开发复杂度:避免多仓库切换与依赖同步问题,提高开发效率

构建 Monorepo 项目

  1. 全局安装

    npm install pnpm -g

  2. 创建 monorepo 仓库:

bash 复制代码
mkdir monorepo && cd monorepo
pnpm init
  1. 在根目录下添加 pnpm-workspace.yaml 文件,告诉 pnpm 当前 Monorepo 中哪些目录属于 workspace
makefile 复制代码
packages:
  - "apps/*"				这是存放"业务应用"的地方,通常是最终运行的项目,比如后台、前台、小程序等。
  - "packages/*"		这是存放"可复用模块/工具库/组件"的地方,所有 apps/ 中的项目可以直接使用它们。
  1. 添加项目
bash 复制代码
mkdir apps && cd apps

# apps-a
mkdir apps-a && cd apps-a
pnpm init

# apps-b
mkdir ../apps-b && cd ../apps-b
pnpm init
  1. 安装依赖
csharp 复制代码
// 安装依赖
pnpm install

// 安装包到根
pnpm add xxx -w

// 安装项目到特定项目
pnpm --filter apps-b add name@version -D

具体的可以看文档:pnpm.io/zh/cli/add

  1. 启动项目
scss 复制代码
// 不需要进到特定的项目来操作
// xxxx  子项目package配置的name名称
pnpm --filter xxxx start 

安装包的原则:

  1. 一般公共的包都是安装到最外层 ,除了版本原因等需要"覆盖的"则安装到特定的项目里
  2. 所有的项目都需要package.json,package.json的name一般是以"@"作为开头,比如@falcon-covoy,这块需要改;
  3. apps-aapps-bpackage.json都是单独的,需要提取公共的包到最外层的package.json
  4. 项目需要完善的部分:Changesets、Semantic-release、Turbopack、Sonar、Commitlint、Sentry报警、Sentry Transcation业务统计等工具
相关推荐
铭毅天下3 分钟前
EasySearch Rules 规则语法速查手册
开发语言·前端·javascript·ecmascript
GISer_Jing14 分钟前
AI Agent操作系统架构师:Harness Engineer解析
前端·人工智能·ai·aigc
英俊潇洒美少年23 分钟前
css中专门用来提升渲染性能、减少重排重绘的属性
前端·css
天若有情67336 分钟前
前端HTML精讲01:别再乱 div 一把抓,吃透语义化标签才是进阶第一步
前端·html
Highcharts.js37 分钟前
React 开发者的图表库生态:Highcharts React
前端·react.js·前端框架
阿部多瑞 ABU37 分钟前
文明文化悖论
前端·人工智能·ai写作
钛态1 小时前
Flutter 三方库 react 泛前端核心范式框架鸿蒙原生层生态级双向超能适配:跨时空重塑响应式单向数据流拓扑与高度精密生命周期树引擎解耦视图渲染控制中枢(适配鸿蒙 HarmonyOS ohos)
前端·flutter·react.js
全栈前端老曹1 小时前
【前端地图】地图开发基础概念——地图服务类型(矢量图、卫星图、地形图)、WGS84 / GCJ-02 / BD09 坐标系、地图 SDK 简介
前端·javascript·地图·wgs84·gcj-02·bd09·地图sdk
只与明月听1 小时前
RAG深入学习之向量数据库
前端·人工智能·python
吕不说1 小时前
AI 面试总挂?可能是表达出了问题:三层表达法 + STAR 进阶框架
前端