Monorepo可能没你想象中那么香……

全文共2500字,预计学习时长10分钟

 

图源:slideshare

 

最近许多流行的开源项目都存在这样的现象,就是在一个存储库中包含多个npm微包,React、Parcel、Babel等等皆是如此。

 

然而Monorepo可能没你想象中那么香,笔者认为,在大多数情况下,这种模式对项目是弊大于利的,它引入了不必要的复杂性,牺牲了作者和开发人员的可用性。

 

 

为什么选择Monorepos?

 

monorepos的概念是简化依赖项管理。如果项目包含许多包,这些包需要依赖于彼此的特定版本,那么将它们放在一个地方而不是放在单独的存储库中就可以更容易地管理。

 

同样,对于一个历史记录,这些包将始终具有同步或“原子”提交。为了让事情变得更简单,可以使用自定义脚本自动管理所有包的发布,这样一来,没有相应的包,这个包就不会发布。

 

一个JavaScriptmonorepo项目通常会有这样的结构:

 

myproject.git/
    packages/
        package-1/
            package.json
        package-2/
            package.json
        package-3/
            package.json
        ...
    scripts/
        common-publishing-script.js

 

这只是一个小例子,你可以看到monorepos可以得到多大的值:

 

· React: 32个包

(https://github.com/facebook/react/tree/master/packages)

 

· Parcel: 81个包

(https://github.com/parcel-bundler/parcel/tree/v2/packages)

 

· Babel: 138个包

(https://github.com/babel/babel/tree/master/packages)

 

这很荒谬&

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值