Как создать том kubernetes NFS в Google Container Engine

Я пытаюсь создать том NFS Kubernetes в Google Container Engine (GKE) и использовать его при развертывании.

Я сделал это в несколько шагов, как показано в этом репозитории github kubernetes-nfs-volume -on-gke:

  1. Создайте кластер GKE и постоянный диск GCE
  2. Настройте контекст для kubectl для работы с кластером GKE
  3. Создание PersistentVolume (PV) и PersistentVolumeClaim (PVC)
  4. Создание сервера NFS
  5. Создайте службу для сервера NFS, чтобы предоставить ее (IP-адрес этой службы используется для создания NFS PV и NFS PVC)
  6. Создание тома NFS
  7. Создайте развертывание busybox для проверки доступности тома NFS.

После выполнения этих шагов полученная ошибка:

$ kubectl describe pods  nfs-busybox-2762569073-lhb5p
Name:       nfs-busybox-2762569073-lhb5p
Namespace:  default
Node:       gke-mappedinn-cluster-default-pool-f94cb0d4-fmfb/10.240.0.3
Start Time: Wed, 12 Apr 2017 04:12:20 +0400
Labels:     name=nfs-busybox
        pod-template-hash=2762569073
Annotations:    kubernetes.io/created-by={"kind":"SerializedReference","apiVersion":"v1","reference":{"kind":"ReplicaSet","namespace":"default","name":"nfs-busybox-2762569073","uid":"b1e523ae-1f14-11e7-a084-42010a8e0...
        kubernetes.io/limit-ranger=LimitRanger plugin set: cpu request for container busybox
Status:     Pending
IP:     
Controllers:    ReplicaSet/nfs-busybox-2762569073
Containers:
  busybox:
    Container ID:
    Image:      busybox
    Image ID:       
    Port:       
    Command:
      sh
      -c
      while true; do date > /mnt/index.html; hostname >> /mnt/index.html; sleep $(($RANDOM % 5 + 5)); done
    State:      Waiting
      Reason:       ContainerCreating
    Ready:      False
    Restart Count:  0
    Requests:
      cpu:      100m
    Environment:    <none>
    Mounts:
      /mnt from my-pvc-nfs (rw)
      /var/run/secrets/kubernetes.io/serviceaccount from default-token-20n4b (ro)
Conditions:
  Type      Status
  Initialized   True
  Ready     False
  PodScheduled  True
Volumes:
  my-pvc-nfs:
    Type:   PersistentVolumeClaim (a reference to a PersistentVolumeClaim in the same namespace)
    ClaimName:  nfs
    ReadOnly:   false
  default-token-20n4b:
    Type:   Secret (a volume populated by a Secret)
    SecretName: default-token-20n4b
    Optional:   false
QoS Class:  Burstable
Node-Selectors: <none>
Tolerations:    <none>
Events:
  FirstSeen LastSeen    Count   From                                SubObjectPath   Type        Reason      Message
  --------- --------    -----   ----                                -------------   --------    ------      -------
  5m        5m      1   default-scheduler                               Normal      Scheduled   Successfully assigned nfs-busybox-2762569073-lhb5p to gke-mappedinn-cluster-default-pool-f94cb0d4-fmfb
  3m        48s     2   kubelet, gke-mappedinn-cluster-default-pool-f94cb0d4-fmfb           Warning     FailedMount Unable to mount volumes for pod "nfs-busybox-2762569073-lhb5p_default(b1e7c901-1f14-11e7-a084-42010a8e0116)": timeout expired waiting for volumes to attach/mount for pod "default"/"nfs-busybox-2762569073-lhb5p". list of unattached/unmounted volumes=[my-pvc-nfs]
  3m        48s     2   kubelet, gke-mappedinn-cluster-default-pool-f94cb0d4-fmfb           Warning     FailedSync  Error syncing pod, skipping: timeout expired waiting for volumes to attach/mount for pod "default"/"nfs-busybox-2762569073-lhb5p". list of unattached/unmounted volumes=[my-pvc-nfs]
  37s       37s     1   kubelet, gke-mappedinn-cluster-default-pool-f94cb0d4-fmfb           Warning     FailedMount MountVolume.SetUp failed for volume "kubernetes.io/nfs/b1e7c901-1f14-11e7-a084-42010a8e0116-nfs" (spec.Name: "nfs") pod "b1e7c901-1f14-11e7-a084-42010a8e0116" (UID: "b1e7c901-1f14-11e7-a084-42010a8e0116") with: mount failed: exit status 32
Mounting command: /home/kubernetes/bin/mounter
Mounting arguments: 10.247.250.208:/exports /var/lib/kubelet/pods/b1e7c901-1f14-11e7-a084-42010a8e0116/volumes/kubernetes.io~nfs/nfs nfs []
Output: Running mount using a rkt fly container
run: group "rkt" not found, will use default gid when rendering images 

В дашборде kubernetes ошибка выглядит следующим образом:

Невозможно смонтировать тома для модуля "nfs-busybox-2762569073-lhb5p_default (b1e7c901-1f14-11e7-a084-42010a8e0116)": истекло время ожидания подключения / монтирования томов для модуля "default" / "nfs-busybox- 2762569073-lhb5p ". список неподключенных / несмонтированных томов = [my-pvc-nfs]

Ошибка синхронизации модуля, пропуск: истекло время ожидания подключения / монтирования томов для модуля «default» / «nfs-busybox-2762569073-lhb5p». список неподключенных / несмонтированных томов = [my-pvc-nfs]

Я что-то упустил?

Спасибо,


person Amine Jallouli    schedule 12.04.2017    source источник
comment
В настоящее время я планирую написать учебник по NFS на GKE. Я не знаю ответа сразу, но спасибо, что задали этот вопрос, так как он подтверждает необходимость такого руководства. Если вы хотите оставаться на связи, мой адрес электронной почты - ahmetb✳︎google.com. Я могу ответить на этот вопрос через несколько недель.   -  person Ahmet Alp Balkan    schedule 13.04.2017
comment
Спасибо за ваше предложение ... Я все еще работаю над ... Если найду решение, опубликую его здесь ... Если вы хотите сделать пиар kubernetes-nfs-volume-on-gke будет здорово!   -  person Amine Jallouli    schedule 13.04.2017


Ответы (1)


Этот комментарий в issue на kubernetes, похоже, решает эту проблему NFS на GKE.

Цитата из этого комментария:

Изменить examples/volumes/nfs/nfs-pv.yaml заменить последнюю строку на путь: "/".

Изменить examples/volumes/nfs/nfs-server-rc.yaml изменить образ на тот, который включил образ NFSv4: gcr.io/google_containers/volume-nfs:0.8

Также есть другие проблемы, которые отслеживаются здесь и здесь.

person surajd    schedule 20.04.2017