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的更多相关文章

  1. 一文看懂npm、yarn、pnpm之间的区别

    文作者对比了当前主流的包管理工具npm.yarn.pnpm之间的区别,并提出了合适的使用建议,以下为译文: NPM npm是Node.js能够如此成功的主要原因之一.npm团队做了很多的工作,以确保n ...

  2. [转] 一文看懂npm、yarn、pnpm之间的区别

    [From] http://geek.csdn.net/news/detail/197339 原文:Understanding differences between npm, yarn and pn ...

  3. npm命令 VS yarn命令

    npm yarn 说明 npm init yarn init  在项目中引导创建一个package.json文件 npm install yarn install/yarn  安装所有依赖包(依据pa ...

  4. 解决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 ...

  5. npm、yarn、pnpm

    它们都是当前主流的包管理工具 pnpm:https://github.com/pnpm/pnpm yarn: https://github.com/yarnpkg/yarn npm: https:// ...

  6. npm淘宝镜像cnpm

    npm install -g cnpm --registry=https://registry.npm.taobao.org

  7. npm 加速方案

    使用npm install 包,是见比较头疼的事情,比较慢,很难等,经过探索,还是发现有办法加速的,方法有两个,让我一一道来: 1. 在npm 后添加参数 --registry=... 指定镜像源地址 ...

  8. 如何使用淘宝 NPM 镜像,安装CNPM的方法

    npm 版本需要大于 3.0 前提:安装好npm 环境:Linux 直接在linux下输入命令: npm install -g cnpm --registry=https://registry.npm ...

  9. 设置npm taobao源和使用cnpm的不同

    一开始,我直接把npm的源设置为taobao源. 使用中,没发现有什么问题,直到,我要装vue-devtools的时候,出问题了. 在使用,,npm i 时,到下载cypress时,怎么都下载不下来. ...

随机推荐

  1. Httpd服务入门知识-Httpd服务常见配置案例之Apache的工作做状态status页面

    Httpd服务入门知识-Httpd服务常见配置案例之Apache的工作做状态status页面 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.status功能概述 status页 ...

  2. chrome开发者工具--使用 Network 面板测量您的网站网络性能。

    转自:Tools for Web Developers   Network 面板记录页面上每个网络操作的相关信息,包括详细的耗时数据.HTTP 请求与响应标头和 Cookie,等等. TL;DR 使用 ...

  3. 分享一个批量修改文件编码的python脚本

    分享一个自己编写的递归查找子目录,将所有cpp文件编码修改为utf-8编码格式的小脚本 #i!/usr/bin/env python3 # -*- coding:utf-8 -*- import os ...

  4. 算法 dfs —— 将二叉树 先序遍历 转为 链表

    将二叉树拆成链表 中文English 将一棵二叉树按照前序遍历拆解成为一个 假链表.所谓的假链表是说,用二叉树的 right 指针,来表示链表中的 next 指针. Example 样例 1: 输入: ...

  5. Jmeter 局域网的IP欺骗终极解决方案

    ip欺骗是什么?    ip欺骗就是模拟ip.什么意思呢,一个电脑就只有一个ip地址,当然如果有多块网卡的话,会有多个ip地址,一般服务器上有个网卡,咱们自己的电脑一般都只有一个ip地址,但是你做压测 ...

  6. Spring Cloud 之 Feign 知识点:封装了 REST 调用

    Feign Client 会在底层根据你的注解,跟你指定的服务建立连接.构造请求.发起请求.获取响应.解析响应,等等. Feign 的一个关键机制就是使用了动态代理. 首先,如果你对某个接口定义了 @ ...

  7. iOS应用代码注入防护

    在应用开发过程中,我们不仅仅需要完成正常的业务逻辑,考虑应用性能.代码健壮相关的问题,我们有时还需要考虑到应用安全的问题.那么应用安全的问题涉及到很多方面.比如防止静态分析的,代码混淆.逻辑混淆:防止 ...

  8. Trie Service

    Description Build tries from a list of <word, freq> pairs. Save top 10 for each node. Example ...

  9. [RN] React Native 再按一次退出

    实现 React Native 再按一次退出 单页面: ... componentWillMount() { BackHandler.addEventListener('hardwareBackPre ...

  10. Navicat配置跳板机连接数据库

    需求 在开发中,有时候我们会碰到这么一个情况.数据库的服务器在内网,如果想连接,必须得先ssh登陆到跳板机,然后在跳板机ssh到达数据库所在服务器,进而操作数据库.遗憾的是,如果跳板机和数据库所在服务 ...