这是我的 GitHub 操作步骤。 PRIVATE_REQUIREMENT_OWNER_TOKEN
机密已创建并包含具有完整 repo
范围的 GitHub 令牌:
- name: Build docker image
id: docker_build
uses: docker/build-push-action@v2
with:
push: false
context: .
tags: 'username/image:latest'
secrets: |
"github_token=${{ secrets.PRIVATE_REQUIREMENT_OWNER_TOKEN }}"
这是 requirements.txt 中的一行,其中包含指向私有存储库的链接,并在上述步骤中从 Dockerfile 构建 docker 映像时尝试安装:
git+ssh://git@github.com/username/private-repository
该行已添加到 Dockerfile
RUN --mount=type=secret,id=github_token pip install https://$(cat /run/secrets/github_token)@github.com/username/private-repository.git
在 GitHub Actions 中引发以下错误:
#11 [ 6/12] RUN --mount=type=secret,id=PRIVATE_REQUIREMENT_OWNER_TOKEN_SECRET pip install https://$(cat /run/secrets/PRIVATE_REQUIREMENT_OWNER_TOKEN_SECRET)@github.com/username/private-repository.git
#11 sha256:b3d88dd9813db3257b15f53f1eb5a4c593c69ff98ec03cc4d70d564df1a1f7f6
#11 0.697 Collecting https://****@github.com/vassilyvv/django-sinbad.git
#11 0.790 ERROR: HTTP error 404 while getting https://****@github.com/username/private-repository
.git
#11 0.791 ERROR: Could not install requirement https://****@github.com/username/private-repository
.git because of HTTP error 404 Client Error: Not Found for url: https://github.com/username/private-repository
for URL https://****@github.com/username/private-repository.git
但是当我尝试使用相同的令牌在本地机器上克隆存储库时,它进行得很顺利:
git clone https://<token>@github.com/username/private-repository.git
我完全不知道如何使用这个 github_token
成功克隆上面提到的私有存储库。
我的目标是在 GitHub Actions 中从 Dockerfile 构建 docker 镜像的同时克隆私有 GitHub 存储库。而且我几乎可以肯定我已经执行了一些错误的步骤。请帮忙!
答案 0 :(得分:2)
我认为这是提供给 pip
的 git URL 的问题。如果需要从私有git仓库安装python包,可以使用如下格式。
pip install git+https://<PERSONAL_ACCESS_TOKEN>@github.com/username/private-repo.git
所以在你的情况下,它将是:
pip install git+https://$(cat /run/secrets/github_token)@github.com/username/private-repository.git