关于npm 镜像源你想知道的都在这里了

npm、npm registry 和 npm 镜像源的关系

npm(Node Package Manager)是一个 JavaScript 包管理器,它允许开发者安装、共享和管理依赖,npm 也是一个cli,用于与 npm 的在线服务交互,这个在线服务就是 npm registry。

npm registry 是一个大型的数据库,用于存储公开发布的 JavaScript 代码包。当使用 npm install 命令安装一个包时,npm 客户端会与 npm registry 通信,下载并安装请求的包。

npm 镜像源是 npm registry 的一个镜像,它包含了 npm 官方库中的所有包的副本,用于提高下载速度,特别是在某些地区访问官方源可能较慢或不稳定的情况下。通过切换到一个更快或地理位置更近的镜像源,开发者可以更快地下载和安装 npm 包。

可用源

npm 官方原始镜像

registry.npmjs.org

国内访问极慢,甚至不能访问

yarn 官方源

registry.yarnpkg.com/

慎用,国内不能访问

淘宝 NPM 镜像

registry.npmmirror.comregistry.npm.taobao.org

registry.npm.taobao.orgregistry.npmmirror.com 实际上它们指向的是同一个服务。根据最新的信息,原来的 registry.npm.taobao.org 已经被替换为 registry.npmmirror.com。当点击 registry.npm.taobao.org 时,会自动跳转到 registry.npmmirror.com现在推荐使用registry.npmmirror.com

原淘宝 npm 域名即将停止解析,正如在《淘宝 NPM 镜像站喊你切换新域名啦》 中预告的那样:npm.taobao.orgregistry.npm.taobao.org 将在 2022.06.30 号正式下线和停止 DNS 解析。域名切换规则:

npm.taobao.org => npmmirror.com registry.npm.taobao.org => registry.npmmirror.com

  1. 切换
bash 复制代码
npm config set registry https://registry.npmmirror.com
  1. 验证命令
bash 复制代码
npm config get registry

如果返回registry.npmmirror.com ,说明镜像配置成功。

腾讯云 NPM 镜像: mirrors.cloud.tencent.com/npm/

1、切换

bash 复制代码
npm config set registry http://mirrors.cloud.tencent.com/npm/
  1. 验证命令
bash 复制代码
npm config get registry

如果返回mirrors.cloud.tencent.com/npm/,说明镜像配置成功。

华为云 NPM 镜像: mirrors.huaweicloud.com/repository/...

  1. 切换
bash 复制代码
npm config set registry https://mirrors.huaweicloud.com/repository/npm/
  1. 验证命令
bash 复制代码
npm config get registry

如果返回mirrors.huaweicloud.com/repository/...,说明镜像配置成功。

设置源

使用命令行设置全局源

上面的 npm config set registry 命令会设置全局源,例如

bash 复制代码
npm config set registry https://registry.npmmirror.com

使用 nrm 工具管理多个源

nrm 是一个 npm 源管理器,可以快速切换不同的源。首先安装 nrm:

bash 复制代码
npm install -g nrm

然后使用 nrm use 来切换源,例如:

bash 复制代码
nrm use taobao

设置临时源

只针对当前 npm install 命令生效

在命令行中临时为要安装的包指定源: 通过 --registry 参数来临时指定源。例如:

bash 复制代码
npm install express --registry https://registry.npmmirror.com

设置项目源

该方法只针对当前项目生效

创建项目根目录下的 .npmrc 文件。在 .npmrc 文件中添加或修改 registry 的值:

bash 复制代码
registry=https://registry.npmmirror.com

保存 .npmrc 文件后,可以通过运行 npm config ls 命令来查看当前项目的配置,确保源已经被正确设置。

设置命名空间源

该方法只针对某个命令空间的内的包生效

在 .npmrc 中设置

bash 复制代码
@xdf:registry=https://registry.npmmirror.com

或者使用命令行操作:

bash 复制代码
npm config set "@xdf:registry" "https://registry.npmmirror.com"

总结

npm 源配置常用方法以上都已列出,对于 yarnpnpm 用法也是一致的,只不过yarn的配置文件使用 .yarnrc。

相关推荐
yinuo21 小时前
前端跨页面通讯终极指南④:MessageChannel 用法全解析
前端
前端布鲁伊1 天前
聊聊前端容易翻车的“环境管理”
前端·面试
毕设十刻1 天前
基于Vue的考勤管理系统8n7j8(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
coding随想1 天前
掌控选区的终极武器:getSelection API的深度解析与实战应用
java·前端·javascript
嵌入式小能手1 天前
飞凌嵌入式ElfBoard-文件I/O的深入学习之存储映射I/O
java·前端·学习
沐风。561 天前
Object方法
开发语言·前端·javascript
程序猿小蒜1 天前
基于springboot的医院资源管理系统开发与设计
java·前端·spring boot·后端·spring
仙人掌一号1 天前
梳理SPA项目Router原理和运行机制 [共2500字-阅读时长10min]
前端·javascript·react.js
粥里有勺糖1 天前
视野修炼-技术周刊第128期 | Bun 被收购
前端·javascript·github
用户12039112947261 天前
彻底搞定大模型流式输出:从二进制碎块到“嘚嘚嘚”打字机效果,让底层逻辑飞起来
前端·javascript·面试