我正在尝试运行我使用 Kubernetes 在本地构建的 docker 镜像。
得到以下错误
Failed to pull image "myImage": rpc error: code = Unknown desc = Error response from daemon: pull access denied for myImage, repository does not exist or may require 'docker login'
在 yaml 文件中我给出了
image: myImage
imagePullPolicy: IfNotPresent
在本地我使用 docker-desktop 和 minikube。
我尝试了多种方法,但唯一的方法是制作 myImage 的 tar 并加载到 minikube 中。 我曾尝试使用 eval $(minikube docker-env) 但在此之后我的图像无法构建,因为它从组织关系服务器中提取基本图像。 任何人都可以建议任何其他方式吗?
答案 0 :(得分:1)
不幸的是,我还不能发表评论,所以我必须发布一个答案。您尝试拉取的图像 myImage
不存在于 kubernetes 集群的本地图像缓存中。运行 docker image ls
命令应该会生成本地可用的图像列表。如果 docker 在本地没有找到镜像,它会(默认情况下)去 Docker Hub 寻找镜像。由于列出的映像没有像 someOrganization\
这样的前缀,因此假定该映像是来自 DockerHub 本身的正式发布的映像。由于您本地构建的映像不是官方 Dockerhub 映像,因此它不知道要运行什么。所以问题的核心是你的 minikube 无法访问你构建图像的任何地方。不幸的是,我之前没有使用过 minikube,所以我无法评论如何使用它的任何复杂性。不过,如果我这样留下我的答案,我会失职,所以查看 minikube 的文档(REF:https://minikube.sigs.k8s.io/docs/handbook/pushing/#1-pushing-directly-to-the-in-cluster-docker-daemon-docker-env),您对 eval 做正确的事情。
Sooo...你的 minikube 不是股票/香草,它是从公司回购中提取的?听起来您需要更改您的 minikube,或者您应该重新评估您正在使用的基本映像并修复 Dockerfile。
答案 1 :(得分:0)
要解决此问题,请将 imagePullPolicy
设置为 Never
。
确保在构建映像之前设置 eval $(minikube docker-env)
。