# urm **Repository Path**: mirrors_HaoChuan9421/urm ## Basic Information - **Project Name**: urm - **Description**: Universal Registry Manager 通用的 registry 配置管理工具 - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2021-10-22 - **Last Updated**: 2026-01-31 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # urm (Universal Registry Manager) > 通用的 [registry](https://docs.npmjs.com/misc/registry/) 配置管理工具, 支持多种包管理器([npm](https://www.npmjs.com/)、[yarn](https://classic.yarnpkg.com/)、[berry](https://yarnpkg.com/)),为多项目和多 [scope](https://docs.npmjs.com/misc/scope/) 而设计。
[简体中文](https://github.com/HaoChuan9421/urm/blob/master/README.md) [English](https://github.com/HaoChuan9421/urm/blob/master/README_EN.md) ## 环境要求 Node.js v12 及以上版本。 ## 安装 ```bash npm i -g @haochuan9421/urm # 或 yarn global add @haochuan9421/urm ``` > 安装太慢?`npm i -g @haochuan9421/urm --registry https://registry.nlark.com/` ## 快速入手 ```bash # 显示当前的 registry 配置 $ urm # 根据提示设置 registry 配置 $ urm set # 在安装 scope 为 "@vant" 的包时使用 taobao registry,并把配置文件保存到当前项目 $ urm set taobao --scope @vant --where project # 根据提示删除 registry $ urm unset ``` ## 使用介绍 > 一张图带你了解 URM 的使用 > 一个视频带你了解 URM 的使用 ### 包管理器(npm、yarn...)的 registry 配置 #### 查看当前配置 ```bash # 查看包管理器的 registry 配置 urm current # 别名 urm cur # current 是默认命令,可省略 urm ```
#### 新增配置
```bash
# 按照提示新增一条 registry 配置
urm use
# 别名
urm set
# 跳过提示,直接手动设置,该命令表示在安装 scope 为 "@vant" 的包时使用 taobao registry,并把配置文件保存到当前项目
urm use taobao --scope @vant --where project
# 简写
urm use taobao -s @vant -w project
```
#### 删除配置
- 单个删除
```bash
# 按照提示选择一条 registry 配置删除
urm unuse
# 别名
urm unset
```
- 一次性清空
```bash
# 一次性清除所有可删除的 registry 配置
urm clear
# 跳过确认提示
urm clear -yes
# 简写
urm clear -y
```
#### 工作模式切换
- 临时切换
```bash
# 查看 yarn 的 registry 配置
urm --mode yarn
# 简写
urm -m yarn
# 给 yarn v2 (berry) 新增一条 registry 配置
urm use -m yarn2
# 删除 npm 的 registry 配置
urm unuse -m npm
```
- 永久切换
```bash
# 按照提示选择一个包管理器作为 URM 的默认工作模式。
# 在不通过 --mode 指定其他包管理器的情况下,默认所有的操作都是工作在默认模式下的
urm mode
# 跳过提示,直接设置默认的工作模式为 yarn,目前可选的值有 npm、yarn、yarn2
urm mode yarn
```
### 备选的 registry 列表
#### 查看当前列表
```bash
# 查看所有可选的 registry,列表中的 registry 可以在你执行 urm use 时选择,
# 有了这个列表,可以极大的方便 registry 的设置,无需记住一大串的 URL
urm list
# 别名
urm ls
```
#### 添加 registry
```bash
# 按照提示输入 registry 的名称和 URL
urm list add
# 跳过提示,直接指定 registry 的名称和 URL
urm list add youzan https://npm.youzan.com/
```
#### 删除 registry
```bash
# 按照提示从列表中选择一条删除
urm list del
# 跳过提示,直接从列表中删除名称是 youzan 的 registry
urm list del youzan
```
#### registry 测速
```bash
# 测试名称是 taobao 的 registry 的访问速度,检测的方式是计算访问 `${registry}/-/ping` 地址的耗时
urm list ping taobao
# 所有 registry 全部测速
urm list ping
```

#### 重置列表
```bash
# 恢复列表到默认状态,预设的列表提供了几个国内访问比较稳定、快速的 registry
urm list restore
```
## 编程方式使用
#### 本地安装
```bash
npm i @haochuan9421/urm
# 或
yarn add @haochuan9421/urm
```
#### 使用 urm
```js
const urm = require("@haochuan9421/urm");
(async () => {
// 获取 URM 封装的包管理器 (package manager) 实例
const npmConfig = urm.pmConfig.getPmConfig("npm"); // choices "npm", "yarn", "yarn2"
// 查看包管理器当前的 registry 配置,以数组的格式返回
const curRegistries = await npmConfig.getCurRegistries();
// 设置包管理器的 registry 配置
await npmConfig.setRegistry("@vant", "https://registry.nlark.com/", { whereType: "project" });
// 删除包管理器的 registry 配置
await npmConfig.delRegistry("@vant", { whereType: "project" });
// 清除包管理器的全部 registry 配置
await npmConfig.clearRegistry();
})();
```
具体可以参考 `lib/pm-config` 文件夹,不同的包管理器在方法的实现上不尽相同,但是实现的接口都是一样的,这有利于后续支持其他的包管理器。
## Star 趋势
[](https://starchart.cc/haochuan9421/urm)