Skip to content

ShengChih/monorepo-pnpm

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

init

mkdir monorepo-example
cd monorepo-example
pnpm init

touch pnpm-workspace.yaml
echo "shamefully-hoist=true" >> .npmrc

multiple-project

monorepo-example
├── package.json
|__ app
|   ├── (A) next-sample
|   ├── (B) nuxt-sample
├── package
│   ├── (1) animation
│   │   ├── package.json
|   |   └── pnpm-lock.yaml
│   ├── (2) data
│   │   ├── package.json
|   |   └── pnpm-lock.yaml
|   ├── (3) react
│   │   ├── package.json
|   |   └── pnpm-lock.yaml
│   └── (4) lib
|       ├── index.js
|       ├── utils
|       |   └── validator.js
│       ├── package.json
|       └── pnpm-lock.yaml
├── pnpm-lock.yaml
└── pnpm-workspace.yaml

Monorepo 目的在於想要一個 repo 管理多個 project,需求來自於各個 project 有自己的 package.json。
而依賴在不同時期寫,版本皆不相同。
若專案仍持續使用且不更新套件,維護成本就會相對變高。
另外,各個專案寫的共用 lib 只能互相複製來複製去,或自己重複造輪子,降低開發效率。

優點是可以讓專案的依賴版本切齊,共用 lib 可互相使用
缺點
1. 在於專案很多,build 時間變長
2. 每次依賴版本更新就需要 CI/CD 完整功能測試
3. 因為整份 repo 共用,需要有明確規範來讓不同團隊存取程式
4. git history 相當混亂 ?
5. security,整套被複製走 ?

感覺 pnpm workspace + git submodule 應該可以簡單管理。
用 gitlab 對專案設定 submodule 權限,且也擁有自己的 pnpm-workspace.yaml

甲團隊若使用 vue/nuxt 生態搭配 package 選用 (1) + (4):
> pnpm-workspace.yaml 包含 (B)/(1)/(4) 路徑 (git submodule init + git submodule update -r + pnpm i)

乙團隊若使用 react/next 生態 package 選用 (A) (3) (4) 同上應該就可以了

也有文章提到 shared code 使用 submodule 會有一些小麻煩。

譬如很常更新的 submodule,多人協作就需要會 git submodule,更新會需要常發 PR & Merge ? 這感覺是正常吧

Note:

有人說到如果是關於 framework & utility 使用 monorepo,關於產品商業產品或邏輯就放 git submodule

nx monorepo cache 吃得資源有點兇。

monorepo 在意的是第三方套件跟 lib 能不能有效被共用及維護,降低開發成本。

usage

git clone https://github.com/ShengChih/monorepo-pnpm.git
cd monorepo-pnpm
git submodule update --init --recursive

command

pnpm -F {target} add {third-party or other package}

e.g. 對 ./app/nuxt-sample 專案加入 package/lib 依賴
pnpm -F ./app/nuxt-sample add package/lib

pnpm -F ./app/next-sample add three

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published