npm 加速之 yarn cnpm pnpm
npm 加速之 yarn cnpm pnpm
有没有感觉到使用 npm 的时候很慢? 安装速度 几Kb/s
不说, 还装着装着出错了, 奇奇怪怪的问题.
这种情况大多数还是因为网络的原因, 很多时候虽然 没有直接提示超时
, 但还是可能由于网络原因导致的不能正常提示, 比如断断续续的下载导致安装脚本不完整.
告别龟速一般有几种途径:
使用国内镜像 - 网速优化
所谓国内镜像, 简单来说就是把国外的资源复制一份到国内, 下载的时候从国内下载.
比较常用的的淘宝镜像, 可能用如下命令配置 npm 的镜像:npm config set registry=https://registry.npm.taobao.org
之后安装工具就会明显快得很多.
如果需要管理多个镜像地址, 可以使用 nrm
。
$ nrm ls # 查看所有镜像源, 带 * 号的是正在使用的
* npm ---- https://registry.npmjs.org/
cnpm --- http://r.cnpmjs.org/
nj ----- https://registry.nodejitsu.com/
npmMirror https://skimdb.npmjs.com/registry/
edunpm - http://registry.enpmjs.org/
$ nrm add taobao https://registry.npm.taobao.org/ # 添加镜像源
$ nrm use taobao # 切换镜像源为淘宝
$ nrm test taobao # 查看淘宝镜像的连接速度
使用缓存, 多线程, 锁… - 本地优化
一开始 npm 的依赖管理方式以及安装方式受到不少人的不满, 比如:
深层嵌套, 这会在一些对目录长度有限制的系统上出现问题.
不确定性, 安装时默认会升级小版本, 但很多软件小版本升级也不兼容, 导致重新安装时程序出错.
一些大厂或大牛视图解决类似问题, 开发了其他的管理器, 如 yarn cnpm pnpm ...
, 但常用的就 yarn cnpm .
yarn 主要有以下特性:
- 离线模式, 如果您以前安装过软件包,则可以在没有Internet连接的情况下再次安装它。
- 确定性的, 无论安装顺序如何,都将以完全相同的方式在所有计算机上安装相同的依赖项。
- 网络性能, 可以有效地对请求进行排队,并避免请求瀑布,以最大程度地利用网络。
- 网络弹性, 失败的单个请求不会导致整个安装失败。失败时将自动重试请求。
- 平面模式, 将不匹配的依赖项版本解析为单个版本,以避免创建重复项。
yarn 与 npm 的使用命令有一些不同:
npm | yarn |
---|---|
npm i | yarn |
npm i react -S | yarn add react |
npm un react -S | yarn remove react |
npm i react -D | yarn add react -D |
npm update -S | yarn upgrade |
cnpm 主要有以下特性:
- 自带淘宝镜像
- 简化安装信息
- 与 npm 一致的命令
注意
yarn:
- 使用方式不同, 别搞错
- 由于使用多线程, 在内存小的计算机上安装时, 安装途中会被 kill 掉
npm:
- 由于第三方的压力, npm 也进行了很多改进
- 发布自己的工具时, 建议使用 npm
扩展阅读
yarn: https://github.com/yarnpkg/yarn
cnpm: https://github.com/cnpm/cnpm
pnpm: https://github.com/pnpm/pnpm
文章来源
注: 本文来源于微信公众号 【乐玩nodejs npm工具库】。
npm 加速之 yarn cnpm pnpm的更多相关文章
- 一文看懂npm、yarn、pnpm之间的区别
文作者对比了当前主流的包管理工具npm.yarn.pnpm之间的区别,并提出了合适的使用建议,以下为译文: NPM npm是Node.js能够如此成功的主要原因之一.npm团队做了很多的工作,以确保n ...
- [转] 一文看懂npm、yarn、pnpm之间的区别
[From] http://geek.csdn.net/news/detail/197339 原文:Understanding differences between npm, yarn and pn ...
- npm命令 VS yarn命令
npm yarn 说明 npm init yarn init 在项目中引导创建一个package.json文件 npm install yarn install/yarn 安装所有依赖包(依据pa ...
- 解决create-react-app 后 npm start or yarn start 中出现 的webpack版本问题
解决create-react-app 后 npm start or yarn start 中出现 的webpack版本问题 错误提示信息 There might be a problem with t ...
- npm、yarn、pnpm
它们都是当前主流的包管理工具 pnpm:https://github.com/pnpm/pnpm yarn: https://github.com/yarnpkg/yarn npm: https:// ...
- npm淘宝镜像cnpm
npm install -g cnpm --registry=https://registry.npm.taobao.org
- npm 加速方案
使用npm install 包,是见比较头疼的事情,比较慢,很难等,经过探索,还是发现有办法加速的,方法有两个,让我一一道来: 1. 在npm 后添加参数 --registry=... 指定镜像源地址 ...
- 如何使用淘宝 NPM 镜像,安装CNPM的方法
npm 版本需要大于 3.0 前提:安装好npm 环境:Linux 直接在linux下输入命令: npm install -g cnpm --registry=https://registry.npm ...
- 设置npm taobao源和使用cnpm的不同
一开始,我直接把npm的源设置为taobao源. 使用中,没发现有什么问题,直到,我要装vue-devtools的时候,出问题了. 在使用,,npm i 时,到下载cypress时,怎么都下载不下来. ...
随机推荐
- 一键配置树莓派wifi、静态ip等
系统老是被我玩坏,重新烧录系统后配置又太麻烦,用shell脚本一键配置一下wifi和静态IP #!/bin/bash touch /media/fanghaoyu/boot/ssh echo &quo ...
- spring-mvc.xml 和 application-context.xml的配置与深入理解
在java框架这个话题,前几篇文章是基于搭建ssm项目框架,以及web.xml的配置讲解,本篇主要就ssm框架的其他配置文件进行深入讲解,他们分别是:1.application-context.xml ...
- 05_配置交换机SSH服务(数通华为)
1. 网络拓扑: 2. SW1配置:2.1 配置为Access口,vlan 10:[SW1]vlan 10[SW1-GigabitEthernet0/0/1]port link-type access ...
- CT107D电路解析
1.译码器: 其中,A.B.C为输入端, 对应关系如下: CBA 十进制 输出(低电平) 000 0 Y0 001 1 Y1 010 ...
- golang 配置goproxy 几个可选的地址
对于golang 语言的开发,对于国内来说有点被动,需要想各种方法,一般的解决方法如下: 使用代理工具(翻墙) 配置goproxy 目前发现的几个不错的goproxy 阿里云 配置如下: expo ...
- 【JZOJ6230】【20190625】梦批糼
题目 一个$n\times m \times l $的立方体,有一些位置有障碍 一次操作会随机选择一个立方体,共有\(w\)次操作 询问所有操作都不选到障碍点,被选到至少一次的点的期望 $n ,m,l ...
- 06-图2 Saving James Bond - Easy Version (25 分)
This time let us consider the situation in the movie "Live and Let Die" in which James Bon ...
- Xcode9/iOS 11 无线调试方法
1.确保手机已经升级到 iOS 11 ,Xcode 已经升级到 9.0 版本,用手机连接电脑,打开 Xcode 选择路径如下图 2.勾选 Connect via network ,勾选之后拔掉手机. ...
- linux 查看网卡以及开启网卡
1.查看并分配虚拟网络 我们首先要知道 VMware 三种网络模式的区别. ①.Bridged(桥接模式):就是将主机网卡与虚拟机虚拟的网卡利用虚拟网桥进行通信.在桥接的作用下,类似于把物理主机虚拟为 ...
- Centos7 .net core 2.0安装使用
一.添加dotnet产品Feed sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc sudo sh -c 'ech ...