首页 > 解决方案 > kubernetes 使用 docker 本地镜像创建部署 - 镜像拉取失败

问题描述

我尝试使用来自本地 docker 映像和 docker hub 的 minikube 部署 kubernetes。但两者都不起作用。

方法 1:使用保存并加载 tar 文件,创建镜像并可供 kubectl 使用。

root@arun-desktop-e470:/var/local/dprojects/elasticsearch# kubectl get pods --all-namespaces -o jsonpath="{..image}" |tr -s '[[:space:]]' '\n' |sort |uniq -c|grep elk
      2 elk/elasticsearch:latest

执行以下命令来创建部署:

kubectl run elastic --image=elk/elasticsearch:latest --port=9200
kubectl expose deployment elastic --target-port=9200 --type=NodePort
minikube service elastic --url

从 kubectl describe pod 命令,

  Warning  Failed     122m (x4 over 124m)   kubelet, minikube  Failed to pull image "elk/elasticsearch:latest": rpc error: code = Unknown desc = Error response from daemon: pull access denied for elk/elasticsearch, repository does not exist or may require 'docker login'

方法 2:我确实将图像推送到了我的 docker hub 存储库(https://hub.docker.com/r/get2arun/elk/tags),然后在终端登录到 docker hub 并再次创建了部署。

推送到如下所示的 docker hub,因此我有权将图像推送和拉取到我的 docker hub 帐户。我已经检查了管理存储库下的“合作者”,它有我的 docker hub id。

root@arun-desktop-e470:~# docker push get2arun/elk:elasticsearch_v1
The push refers to repository [docker.io/get2arun/elk]
19b7091eba36: Layer already exists 
237c06a69e1c: Layer already exists 
c84fa0f11212: Layer already exists 
6ca6c301e2ab: Layer already exists 
76dd25653d9b: Layer already exists 
602956e7a499: Layer already exists 
bde76be259f3: Layer already exists 
2333287a7524: Layer already exists 
d108ac3bd6ab: Layer already exists 
elasticsearch_v1: digest: sha256:6f0b981b5dedfbe3f8e0291dc17fc09d32739ec3e0dab6195190ab0cc3071821 size: 2214

kubectl 运行 elasticsearch-v2 --image=get2arun/elk:elasticsearch_v1 --port=9200

来自 kubectl describe pods 命令:

  Normal   BackOff    21s               kubelet, minikube  Back-off pulling image "get2arun/elk:elasticsearch_v1"
  Warning  Failed     21s               kubelet, minikube  Error: ImagePullBackOff
  Normal   Pulling    7s (x2 over 24s)  kubelet, minikube  Pulling image "get2arun/elk:elasticsearch_v1"
  Warning  Failed     4s (x2 over 21s)  kubelet, minikube  Failed to pull image "get2arun/elk:elasticsearch_v1": rpc error: code = Unknown desc = Error response from daemon: pull access denied for get2arun/elk, repository does not exist or may require 'docker login'

我删除了代理设置并尝试打开 wifi 帐户,但仍然看到权限被拒绝。

此错误消息不足以识别问题,希望有某种方法可以缩小此类问题的范围。

  1. 当 Kubernetes 被要求使用本地 docker 镜像或从 docker hub 拉取镜像时,后台会发生什么?
  2. 开始部署时如何获取所有日志信息?
  3. 日志的其他来源是什么

标签: dockerkubernetesminikube

解决方案


在方法一中,由于镜像没有推送到仓库,所以必须使用 imagePullPolicy。

永远不要尝试拉图像

imagePullPolicy: Never

尝试拉取图像,如果它不存在

imagePullPolicy: IfNotPresent

如果您想使用本地图像/存储库,我认为 IfNotPresent 是理想的。根据您的要求使用。

kubectl

kubectl run elastic --image=elk/elasticsearch:latest --port=9200 --image-pull-policy IfNotPresent

推荐阅读