问题
显然,不管是出于节省流量考虑,还是私有源不够强大不能即时映射上游,或是速度太慢等原因,内网 / 私有 npm registry 源应该只负责管理私有包(大公司除外)。
一般我们把这种私有包都管理到一个作用域 scope 下,比如:@scope/some-pkg 。
在我们的知识储备中,npm_config_* 下面的环境变量会被读取到 npm 作为默认配置,而 npm_config_registry 是 npm 默认下载源。
那如何配置带 scope 作用域前缀的 registry ?让他和默认 registry 分开?
npm 官方默认支持从 .npmrc 中进行区分:
@scope:registry=http://registry.domain.com/
registry=https://registry.npmmirror.com/
但是一旦被读取到环境中,将变为:
-
npm_config_registry:https://registry.npmmirror.com/ -
npm_config__scope_registry:http://registry.domain.com/
那我手动设定 npm_config__scope_registry 指定 scope 源可以吗?这样就不用 .npmrc 配置了。
当然不可以!
解法
此处需要命令行工具开解,如 spawn / execa ,提供一个解法的例子:
const execa = require('execa')
const argv = process.argv.slice(2)
execa('pnpm', argv, {
shell: true,
stdio: 'inherit',
env: {
npm_config_registry: 'https://registry.npmmirror.com/',
'npm_config_@scope_registry': 'http://registry.domain.com/',
...process.env,
},
})
一旦你采用此方式接管了对应的依赖管理工具,即意味着以后安装任何依赖都可以自动分流,识别到 scope 即走私有源,否则走 tb 源。
至于具体拓展场景,各位可以意会,而定义 alias 显然只能单流不能自动分流。