何处安放你那垃圾的封装代码?自建npm仓库万事不求人


title: 何处安放你那垃圾的封装代码?自建npm仓库万事不求人
category: Web
tag: npm
date: 2019-07-14


主标题:何处安放你那垃圾的封装代码?自建npm仓库万事不求人
副标题:如何把你那丢人的代码块放到自建npm仓库里
副标题:自建npm仓库

缘起

在前几篇文章中提到飞冰ice不支持私有仓库,没办法成为我的代码素材库,我反馈给飞冰团队之后,隔了一天,大周末的就新增了对私有npm仓库和自有cdn的支持,之前顾虑npm发包太公开,cdn访问太慢的问题迎刃而解。

飞冰团队给力!:ox::beer:

这篇文章就说说怎么(低成本省时省力不重复造轮子地)自建私有npm仓库。我那丢人现眼的垃圾代码就不拿出去霍霍人了。

何处安放你那垃圾的封装代码?自建npm仓库万事不求人_第1张图片
实例

我们为什么要自建npm?一个是保护私有代码,另一个就是从局域网取文件速度快。

私有npm,发包更省心。

自建私有仓库,目前有几个选择,一个是sinopia 一个是 cnpmjs.org,我先知道的cnpmjs.org 那就先看这个。

cnpmjs.org这个包名字很有特点,是个网址,国人首选的cnpm就是用的这个搭的:

当前 npm.taobao.org 运行版本是: [email protected]

我们可以通过下载或者fork使用这个包。这个包会优先使用本地的包,没有就使用cnpm的包,下次速度有保证。下载完会自动 sync同步,下次下载就从缓存里拿。

cnpmjs.org 自建过程

前置条件

没啥准备条件,电脑有网就行。

数据库有也行,没有也行,提供 mysql 和 sqllite 等数据库支持。

我有一个现成的数据库:本地端口3306的 mysql。

安装 cnpmjs.org

需要先安装这个包,拿到源代码。

npm i -g cnpmjs.org
cnpmjs.org -V #2019-07-14的版本是 2.19.4

修改配置文件

不同系统,配置文件路径不太一样。

Windows

C:\Users\zhongda\AppData\Roaming\npm\node_modules\cnpmjs.org\config\index.js

Mac

cnpmjs.org 默认安装路径:/usr/local/lib/node_modules/cnpmjs.org\index.js

nvm

如果你使用 nvm,安装路径在这:~/.nvm/versions/node/v10.15.3/lib/node_modules/cnpmjs.org/config/index.js

修改并注意以下内容:

  • bindingHost: '0.0.0.0' 允许局域网访问

  • enableCompress: true 启用gzip压缩,很奇怪为什么默认关闭

  • admins 这里填入管理者的信息,方便后续鉴权

  • database 数据库,有就写,没有就使用 sqlite,如果要使用sqlite记得全局安装sqlite

  • nfs 包存到哪,默认是数据目录 nfs 下面,这个魔改一下发到cdn上也不是不行,目前还不用

  • registryHost:'' 注意这里先留空,模块访问域名。如果你下载模块报错就是这个的锅

  • scopes 包前缀,比如 @babel/cli 这样的,多点命名空间

  • syncModel exist 只同步缓存用到的包。这玩意吃硬盘空间,我看了一下快10个g了,拿空间换时间

  • npmClientName 通过什么客户端拉取,默认cnpm

创建数据库并导表

以下参考的是https://zhuanlan.zhihu.com/p/35773211

进入数据库

mysql -uroot -p

create database cnpmjs; # 创建数据库

use cnpmjs;

source ~/xx/docs/db.sql; # 这个在配置文件附近的文件夹

完事会创建大概14个表。

启动

cnpmjs.org start

打开 localhost:7002 看看吧。

如果你想要托管,可以尝试pm2:

npm i -g pm2
pm2 start dispatch.js

发个包

自己写个包,让然后发包

cnpm login # 先本地登录,不登录发不了包
npm init -y
touch index.js # 包里有内容了
cnpm publish

可以随便发包了。


有生之年展望:

  • 回头可以再补充点,修改页面样式,看着不好看。

你可能感兴趣的:(何处安放你那垃圾的封装代码?自建npm仓库万事不求人)