Dockerfile
FROM openjdk:8-jre-alpine
WORKDIR /app1/backend
COPY ./target/app1-backend.jar app1-backend.jar
ADD cloudfront_private_key.pem /host_files/
EXPOSE 9000
ENTRYPOINT [ "java", "-cp", "app1-backend.jar", "hsnbe.app1"]
docker-compose.yml
version: '3.4'
services:
app1:
logging:
driver: awslogs
options:
awslogs-region: eu-west-1
image: app1-server:development
container_name: health_backend
build:
context: .
dockerfile: ./build/DockerfileHS.dev
target: app1
restart: unless-stopped
volumes:
- ~/.ssh/health_backend_dev_cloudfront_private_key.pem:${HAPP_AWS_CLOUDFRONT_KEY_FILE_PATH:-/host_files/health_backend_dev_cloudfront_private_key.pem}
ports:
- ${APP1_PORT:-9000}:9000
depends_on:
- postgres
links:
- postgres
错误:
Reason CannotPullContainerError: Error response from daemon: pull access denied for registry.gitlab.com/app1/backend, repository does not exist or may require 'docker login'
我已经尝试过:
检查:
~/.docker/config.json
中查找 auths
部分read-registry
和 write_registry
范围access denied
可能是因为您使用的个人访问令牌 (PAT) 没有访问此容器注册表的项目。
read_registry
scope 才能拉取,并且如果您想推送到容器注册表,还必须具有 also write_registry
范围docker push
私有项目,您至少需要 开发者 访问该项目docker pull
来说,当客人您不能将部署令牌与公共 API 一起使用。它们仅对 CI/CD 作业有用。
access denied
的另一个原因可能是该项目实际上并不存在。您无法推送到 GitLab 中的任意命名空间。在您的示例中,错误显示:
access denied for registry.gitlab.com/app1/backend
backend
的命名空间中没有“@app1
”项目。这甚至可能不是您的命名空间:http://gitlab.com/app1
问题中没有足够的细节,但作为猜测,您可能应该这样做,用您的用户名或组名替换
$GITLAB_USERNAME
,用项目的命名空间替换 $GITLAB_PROJECT_NAMESPACE
:
docker build -t registry.gitlab.com/$GITLAB_USERNAME/$GITLAB_PROJECT_NAMESPACE/app1/backend:1.0
docker push registry.gitlab.com/$GITLAB_USERNAME/$GITLAB_PROJECT_NAMESPACE/app1/backend:1.0
我通过
gitlab-runner
在本地安装了 apt-get
并遇到了同样的问题。
我只能删除已安装的
gitlab-runner
并通过curl
重新安装它才能解决问题
curl -L "https://packages.gitlab.com/install/repositories/runner/gitlab-runner/script.deb.sh" | sudo bash
sudo apt-get install gitlab-runner