问题描述
有人可以提供推荐的解决方案,用于在docker构建阶段针对 Maven , NPM 或 Python 的Azure Artifacts在Dockerfile内部进行身份验证吗? >?
尽管在Stack Overflow或Internet上提到了在从Dockerfile内构建时访问经过身份验证的Azure Artifacts提要的特定问题的大多数解决方案(在下面的各种文章中)都针对nuget生态系统,问题是针对 Maven , NPM 或 Python 软件包的。
在这里感谢帮助。
解决方法
我的问题是针对Maven,NPM或Python软件包的。
这些程序包类型来自不同的系统,因此我们应该使用不同的方式对它们进行身份验证。
对于Maven:
选中set-up-your-feed
。您应该配置pom.xml
文件以定义url,然后使用PAT定义settings.xml
文件。您可以在项目中管理这两个文件,然后使用Dockerfile将settings.xml
复制到${user.home}/.m2
文件夹。
对于NPM:
您可以在此处遵循Other
主题来配置一个包含凭证的.npmrc
。另外,我认为您可以创建一个普通的.npmrc
文件,然后使用Npm Authenticate task
对其进行修改。这是一个working sample。
对于Python:
我们可以使用Pip Authenticate task来填充PIP_EXTRA_INDEX_URL
环境变量,并将其作为构建参数传递。像这样的东西:arguments: --build-arg INDEX_URL=$(PIP_EXTRA_INDEX_URL)
您可以查看this similar issue中的两个答案以了解更多详细信息。