团队需要一个私有npm

一、前言

随着Team人员越来越多,项目间的代码复用显得越来越重要。比如:常用的框架/库、工具方法等。另外团队内部的代码模块化,也需要有一个机制来管理。目前npm是前端代码的包管理(类似iOS 的cocoapods、android的gradle)首选。于是,我尝试使用私有npm搭建一套前端仓库,用以在公司内部托管公共代码以及将代码模块化。

二、选型

npm+私有git仓库

制作&使用

1.新建私有git仓库(如:https://gitlab.com/mygroup/myproject.git),用group建立项目较方便代码的管理,也能作为npm的scope。

  • clone仓库
git clone https://gitlab.com/mygroup/myproject.git

2.npm init

npm init --scope=mygroup

3.push到仓库即可

4.安装

"@mygroup/myproject": "https://gitlab.com/mygroup/myproject.git"

5.使用

var myproject = require('@mygroup/myproject');
优缺点

缺点:不能使用npm直接update
优点:简单直接

npmjs官方托管

制作&使用

参考官方教程https://docs.npmjs.com/private-modules/intro

优缺点

缺点:需要支付每个月7刀; 不能使用npm直接update;
优点:简单直接;开源&闭源项目同一托管

使用verdaccio自己托管

《团队需要一个私有npm》 verdaccio

制作&使用

1.安装verdaccio

npm install --global verdaccio 

2.启动服务

verdaccio

3.团队人员都绑定registry

npm set registry http://verdaccio托管的ip地址:4873

4.增加用户

npm adduser --registry http://verdaccio托管的ip地址:4873

5.发布私有库

npm publish --registry http://verdaccio托管的ip地址:4873

6.安装私有库

npm i 私有库名称

7.使用私有库

var 私有库名称 = require('私有库名称');
优缺点

优点:免费;本地速度快&带公有库缓存;支持yarn
缺点:需要自己托管维护

注:为了切换源方便,可以使用nrm

安装

npm install -g nrm

增加私有源

nrm add 私有源名称 http://verdaccio托管的ip地址:4873

列出所有源(*表示现在正在使用的源)

$ nrm ls

* npm ---- https://registry.npmjs.org/
  cnpm --- http://r.cnpmjs.org/
  eu ----- http://registry.npmjs.eu/
  au ----- http://registry.npmjs.org.au/
  sl ----- http://npm.strongloop.com/
  nj ----- https://registry.nodejitsu.com/
私有源名称  http://verdaccio托管的ip地址:4873

切换源

$ nrm use 自定义私有库名称
   Registry has been set to: http://verdaccio托管的ip地址:4873

三、总结

基于上面选型中的分析,我最终选择了verdaccio。私有npm的作用,不单单是作为包管理器,更是项目模块化的一种“约束”。这样一来,你就不会往一个模块随意加入本该属于另外一个模块的代码,也就是会逼迫你去做解耦。另外有了私有npm,每个模块更“独立化”,能“专心”为其加入单元测试&持续集成等实践,使每个模块的质量能得到较好的保障,提高整体软件的质量。

    原文作者:CatchZeng
    原文地址: https://www.jianshu.com/p/65dd2f26d47c
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞