写点什么

npm 官宣:未来将支持 monorepo 特性,带来源码管理新姿势!

  • 2019-08-02
  • 本文字数:1671 字

    阅读完需:约 5 分钟

npm官宣:未来将支持monorepo特性,带来源码管理新姿势!

npm 存在的问题

从架构的角度来看,将大型单体代码库拆分为较小的、独立封装的一系列模块通常是个好方法。从微服务到可复用组件库,很多技术都很适合模块化。但从版本发布和源代码管理的角度来看,它也可能是一场噩梦。


  • 当项目有数十乃至数百个代码存储库时,发现工作也变得愈加困难。每当创建一个新的存储库,所有人必须将其添加到自己的代码模块中。

  • 访问控制成了单调乏味的工作,且容易出错,尤其是得在“需要了解”的基础上一次一个地授予存储库访问权限,实在令人头疼。新员工经常要经历无止境的依赖项地狱。每个访问请求都会引出它们需要访问的另外两个存储库来。

  • 高度模块化的架构也使版本控制变复杂了。我们可以让一系列相关模块的版本同步更新,给它们做“快照”(例如 Babel 和 React 就是这么做的)。但要让人们为那么多的包做这种工作(还包括和他们没什么关系的包)就是在自找麻烦。

  • 包之间的依赖项重复会大大增加安装依赖项所需的时间。一些生态系统(特别是 npm)是高度模块化的。模块化会鼓励复用,但也意味着某些包可能在你开发的每个包里都复制了一份。

解决方案

Monorepo 是针对这个问题的流行解决方案。它意味着你会将所有模块放在同一个代码存储库中,而不是每个模块配一个代码存储库。然后开发者在开发应用时只用这个“monorepo”就够了。由于所需的内容都放在了一起,发现、访问控制和版本控制工作都变得更加简单。


显然,代价就是你只能对所有代码做整体权限控制。但如果你能接受这一点,monorepo 就能在兼顾模块化所有优势的前提下提供非常简单的源代码管理方法。


那么 monorepo 怎样搭配 npm 使用呢?最受欢迎的两大解决方案分别是 Yarn workspaces 和 lerna。由于 lerna 支持 npm,让我们来看看它是如何实现 monorepo 的。


首先我们全局安装 lerna。


$ npm install -g lerna
复制代码


接下来,我们需要创建新的 lerna 存储库:


$ mkdir monorepo_example$ cd monorepo_example$ lerna init
复制代码


查看 lerna.json 可以看到版本和包的定义位置。


$ cat lerna.json{“packages”: [“packages/*”],“version”: “0.0.0”}
复制代码


如上所示,我们的 monorepo 中所有包的版本都是 0.0.0。但是我们的 monorepo 中还没有任何包。在我们添加包之前应该先登录到我们的存储库,以便 lerna 在每个新包上正确设置 publishConfig。


如果你要发布在公共 npm 存储库之外的位置上(例如 npm Enterprise),则首先需要设置你的存储库。


$ npm config set registry https://registry.npm.yourcompany.com
复制代码


接下来,我们用具有发布权限的用户登录到存储库中。如果你的包没有作用域,则可以省略-scope 标志。


$ npm login -scope test
复制代码


现在为我们的 monorepo 添加一些定域包(scoped package)。


$ lerna create @ test / a$ lerna create @ test / b$ lerna create @ test / c
复制代码


如果你为每个包选择了默认设置,那么现在测试域内会有三个包(a、b、c),版本为 0.0.0。在更新版本之前,我们需要提交已完成的工作的并为 git 创建一个远程连接:


$ git add。$ git commit -m “Initial commit”$ git remote add origin git@github.com:username/reponame.git$ git push -u origin master
复制代码


现在我们可以使用一个命令来更新所有包的版本。


$ lerna version major
复制代码


此命令不仅会将每个包都更新到 1.0.0,还会为你推送版本更新到 git。最后一步是将这些包发布到 npm。Lerna 用一个命令就能完成这个任务。


$ lerna publish from-git
复制代码


这条命令成功运行后,你就成功将第一个 monorepo 中的所有包都发布到 npm 了。万岁!


我们总结一下:


  1. 用 Lerna 创建一个新的 monorepo。

  2. 为我们的 monorepo 添加了三个新的定域包。

  3. 更新了所有包的版本并使用一条命令提交给了 git。

  4. 使用一条命令将所有包发布到了 npm 存储库。


有关 Lerna 的更多信息,包括解决重复问题的方案,建议查阅他们提供优秀的文档

未来计划

我们也很高兴地宣布,我们计划为 npm@7 带来一流的 monorepo 支持。如果你在搭配 monorepo 使用 npm,我们需要你的反馈!请告诉我们你对目前的 monorepo 解决方案的看法。


编程愉快!


英文原文:https://blog.npmjs.org/post/186494959890/monorepos-and-npm


2019-08-02 18:313711

评论

发布
暂无评论
发现更多内容

WebRTC 作者加入 OpenAI 主导实时 AI 项目;TTS 小模型 OuteTTS v0.2 发布:声音克隆+多语言

声网

Rust 错误处理在 GreptimeDB 的实践

Greptime 格睿科技

rust 错误 错误处理

AIC和ScaleFlux(锐钲)发布基于NVIDIA BlueField-3 DPU的新型存储阵列

ScaleFlux

显式等待与隐式等待详解:Selenium 自动化测试中的关键概念

测吧(北京)科技有限公司

测试

如何选择最适合企业的ETL解决方案?

RestCloud

kettle ETL 数据集成 DataX ETLCloud

Pytest 结合数据驱动的用法详解

测吧(北京)科技有限公司

测试

Page Object 设计模式:实现 Selenium 测试用例的良好分层

测吧(北京)科技有限公司

测试

创新实践:基于边缘智能的边云协同智能驾驶训练舱解决方案

火山引擎边缘云

IoT 智能驾驶 大模型 AI 基础设施 边缘智能

京东商品详情数据接口调用,商城上货实战案例(仅供参考)

tbapi

京东API接口 京东商品详情接口

国内首家! 阿里云人工智能平台 PAI 通过 ITU 国际标准测评

阿里云大数据AI技术

人工智能 阿里云 PAI ITU

Pytest 编写自动化测试用例规则

测吧(北京)科技有限公司

测试

Web兼容性测试思路详解

测吧(北京)科技有限公司

测试

软件测试丨Pytest 参数化与调度执行

测试人

软件测试

用豆包MarsCode ,陪你云赏月

Trae

Web兼容性测试思路详解

测吧(北京)科技有限公司

测试

比特币临近10万美元回调:后市走势与关键因素解读

区块链软件开发推广运营

交易所开发 dapp开发 链游开发 公链开发 代币开发

数字化浪潮下的数据资产管理:解锁保险行业的无限潜能

数造万象

保险 数据治理 数据血缘 数据资产管理 #数据

web 自动化测试框架 cypress全面指南

测吧(北京)科技有限公司

测试

Pytest 框架与常用操作

测吧(北京)科技有限公司

测试

Pytest 参数化与基本装饰器用法

测吧(北京)科技有限公司

测试

如何使用PHP开发1688商品详情API接口

科普小能手

数据采集 1688 API 接口 1688代采 1688 API

Selenium 框架与常用操作详解

测吧(北京)科技有限公司

测试

Altair 助力eVTOL,与航空航天初创企业Moya Aero合作

Altair RapidMiner

测试 仿真 智能制造 航天航空 altair

想要进行Facebook直播?快来看看这份详细指南!

Ogcloud

海外直播专线 海外直播 海外直播网络 facebook直播 facebook运营

Pytest框架:提升软件测试的利器

测试人

软件测试

Supersonic 推出混合休闲游戏开发大赛 为开发者提供丰厚资金支持与专家指导

极客天地

并行区块链全解:执行原理、代表项目及技术发展周期

区块链软件开发推广运营

交易所开发 dapp开发 链游开发 公链开发 钱包开发

App 测试必学技能 adb 命令

测吧(北京)科技有限公司

测试

自动化测试中常用的 JavaScript 脚本

测吧(北京)科技有限公司

测试

npm官宣:未来将支持monorepo特性,带来源码管理新姿势!_编程语言_npm 博客_InfoQ精选文章