【问题标题】:AWS Codeartifact and docker build cacheAWS Codeartifact 和 docker 构建缓存
【发布时间】:2021-09-24 04:18:41
【问题描述】:
【问题讨论】:
标签:
docker
pip
docker-build
aws-codeartifact
【解决方案1】:
看起来 docker buildkit 就是答案。
生成文件:
docker_build:
@$(eval CODEARTIFACT_AUTH_TOKEN := $(shell aws codeartifact get-authorization-token --domain your-domain --domain-owner your-id --region your-region --query authorizationToken --output text --duration-seconds 900))
@pip config set global.index-url "https://aws:${CODEARTIFACT_AUTH_TOKEN}@<your-domain>-<your-id>.d.codeartifact.<your-region>.amazonaws.com/pypi/your-repo/simple/"
cp ~/.config/pip/pip.conf /tmp/pip.conf
DOCKER_BUILDKIT=1 docker build --progress=plain --secret id=pip.conf,src=/tmp/pip.conf -t tmp_docker_image .
Dockerfile:
FROM python:3.8.8-slim-buster
WORKDIR /code
ADD requirements.txt /code/requirements.txt
RUN --mount=type=secret,id=pip.conf,dst=/root/.pip/pip.conf \
pip install -r ./requirements.txt
我已经测试了几次,每次运行都更改了令牌,看起来不错。
这个帮助了:https://dev.to/hugoprudente/managing-secrets-during-docker-build-3682