问题
显然,不管是出于节省流量考虑,还是私有源不够强大不能即时映射上游,或是速度太慢等原因,内网 / 私有 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
显然只能单流不能自动分流。