7

我在 macOS 10.12 上使用 minikube 并尝试使用托管在 docker hub 上的私有图像。我知道 minikube 启动了一个 VM,据我所知,它将是我本地 kubernetes 集群的唯一节点,它将托管我所有的 pod。

我读到我可以通过运行来使用 VM 的 docker 运行时eval $(minikube docker-env)。所以我使用这些变量从我的本地 docker 运行时更改为另一个。运行docker images我可以看到更改已有效完成。

我的下一步是使用 docker hub 登录,docker login然后手动拉取我的图像,最终没有错误。在那之后,我认为该图像将准备好被集群中的任何 pod 使用,但我总是得到ImagePullBackOff. 我也尝试通过 ssh 进入虚拟机minikube ssh,结果是一样的,图像可以使用,但由于某种原因,我不知道它拒绝使用它。

如果有帮助,这是我的部署描述文件:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: web-deployment
spec:
  replicas: 1
template:
  metadata:
    labels:
      app: nginx
  spec:
    containers:
    - name: nginx
      image: godraude/nginx
      imagePullPolicy: Always
      ports:
      - containerPort: 80
      - containerPort: 443

这是输出kubectl describe pod <podname>

Events:
  FirstSeen LastSeen    Count   From            SubobjectPath       Type        Reason      Message
  --------- --------    -----   ----            -------------       --------    ------      -------
  1m        1m      1   {default-scheduler }                Normal      Scheduled   Successfully assigned web-deployment-2451628605-vtbl8 to minikube
  1m        23s     4   {kubelet minikube}  spec.containers{nginx}  Normal      Pulling     pulling image "godraude/nginx"
  1m        20s     4   {kubelet minikube}  spec.containers{nginx}  Warning     Failed      Failed to pull image "godraude/nginx": Error: image godraude/nginx not found
  1m        20s     4   {kubelet minikube}              Warning     FailedSync  Error syncing pod, skipping: failed to "StartContainer" for "nginx" with ErrImagePull: "Error: image godraude/nginx not found"

  1m    4s  5   {kubelet minikube}  spec.containers{nginx}  Normal  BackOff     Back-off pulling image "godraude/nginx"
  1m    4s  5   {kubelet minikube}              Warning FailedSync  Error syncing pod, skipping: failed to "StartContainer" for "nginx" with ImagePullBackOff: "Back-off pulling image \"godraude/nginx\""
4

2 回答 2

5

我认为您需要创建一个秘密,它将告诉 kube 从哪里可以提取您的私有图像及其凭据

kubectl create secret docker-registry my-secret --docker-server=DOCKER_REGISTRY_SERVER --docker-username=DOCKER_USER --docker-password=DOCKER_PASSWORD --docker-email=DOCKER_EMAIL

下面的命令列出你的秘密

kubectl get secret
NAME            TYPE                      DATA      AGE
my-secret   kubernetes.io/dockercfg   1         100d

现在在部署定义中,您需要定义要使用的哪个密码

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: web-deployment
spec:
  replicas: 1
template:
  metadata:
    labels:
      app: nginx
  spec:
    containers:
    - name: nginx
      image: godraude/nginx
      imagePullPolicy: Always
      ports:
      - containerPort: 80
      - containerPort: 443
    imagePullSecrets:
      - name: my-secret
于 2016-12-10T16:26:23.967 回答
1

问题在于图像拉取策略。它被设置为Always所以 docker 试图拉取 imagen,即使它存在。设置imagePullPolicy: Never解决了这个问题。

于 2016-12-09T12:45:42.260 回答