[英]Jenkinsfile / Docker : pointing to a "npm" private registry
我正在使用 Jenkinsfile 来构建和发布节点包。 在通常的结帐步骤之后,我使用以下代码安装我的组件。
node {
docker.image('node').inside {
sh 'npm install'
}
}
它适用于默认注册表 ( https://registry.npmjs.org )。 但是,如果一个包包含一个指向私有注册表(可通过浏览器访问)的.npmrc
文件,那么它将失败。
如何通过 Jenkinsfile 生成的 docker 容器指向私有寄存器?
非常感谢:)
解决方案在这里: https ://docs.npmjs.com/docker-and-private-modules
基本上,您需要配置 npm 环境才能在npm install
之前调用私有注册表。 在你的机器上你会做一些像npm login
这样的交互,但不适合 docker 构建!
基本上,您需要访问外部网络。 为此,请尝试使用以下代码 -
node {
docker.image('node').inside("--net='bridge' -u root") {
sh 'npm install'
}
}
如果上述代码也不起作用,您始终可以在根级别的 docker 容器中创建自己的 custom.npmrc 文件。 这肯定会确保所有其他 npm 注册表都可以在 docker 容器内访问。
node {
docker.image('node').inside("--net='bridge' -u root") {
def data = "${npmrc}" //your custom npmrc data
writeFile(file: '.npmrc', text: data) //create a new file named .npmrc
sh 'npm install'
}
}
花了一个星期后,我发现了一些多么合理的方法。 只需添加
运行 git config --global url."https://${GIT_ACCESS_TOKEN}@github.com".insteadOf "ssh://git@github.com"
到你的 docker 文件中,如果它也需要安装私有包,它将安装。
添加传递你的 GIT_ACCESS_TOKEN(你可以在你的 github 设置帐户中设置适当的权限)在你构建图像的地方。 像 docker build --build-arg GIT_ACCESS_TOKEN=yourtoken -t imageNameAndTag。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.