Kubernetes на AWS от Kops - динамическая инициализация gp2 не выполняется для кластера с одним узлом;ПВХ в ожидании; - PullRequest
0 голосов
/ 05 марта 2019

Мои ПВХ находятся в состоянии Pending все время.

kubectl describe pvc project-s3-pvc дает:

Name:          project-s3-pvc
Namespace:     default
StorageClass:  gp2
Status:        Pending
Volume:        
Labels:        <none>
Annotations:   kubectl.kubernetes.io/last-applied-configuration:
                 {"apiVersion":"v1","kind":"PersistentVolumeClaim","metadata":{"annotations":{},"name":"project-s3-pvc","namespace":"default"},"spec":{"ac...
               volume.beta.kubernetes.io/storage-provisioner: kubernetes.io/aws-ebs
Finalizers:    [kubernetes.io/pvc-protection]
Capacity:      
Access Modes:  
Events:        <none>
Mounted By:    project-s3-86ccd56868-skvv5
✔ /data/project [kubernetes-aws L|✚ 10⚑ 66

kubectl get storageclass дает:

NAME            PROVISIONER             AGE
default         kubernetes.io/aws-ebs   1h
gp2 (default)   kubernetes.io/aws-ebs   1h

Я использую кластер с 1 узлом, запущенный Kops:

kops create cluster --node-count 0 --zones eu-west-1a ${NAME} --master-size t2.large

# Change size from 2 to 0, since above node-count does seem to be ignored
kops edit ig --name=${NAME} nodes

kops edit cluster ${NAME}

# Add this to cluster specification
iam:
  allowContainerRegistry: true
  legacy: false

kops update cluster ${NAME} --yes

kubectl taint nodes --all node-role.kubernetes.io/master-node

Затем я добавляю PVC, например .:

kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: bomcheck-s3-pvc
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 30Gi

Kops версия: Version 1.11.0 (git-2c2042465)

EDIT: Когда я пытаюсь создать PV вручную:

apiVersion: v1
kind: PersistentVolume
metadata:
  name: pv-manual
spec:
  accessModes:
    - ReadWriteOnce
  awsElasticBlockStore:
    fsType: ext4        
  persistentVolumeReclaimPolicy: Delete
  storageClassName: gp2
  capacity:
    storage: 30Gi

Я получаю: ValidationError(PersistentVolume.spec.awsElasticBlockStore): missing required field "volumeID" in io.k8s.api.core.v1.AWSElasticBlockStoreVolumeSource;

Означает ли это, что мне нужно создать том вперед в AWS вручную? Я хотел бы, чтобы объем был динамически обеспечен.

Любая идея, как отладить, почему PVC / PV не может быть предоставлен от имени моего AWS?

Ответы [ 2 ]

0 голосов
/ 06 марта 2019

Проблема, похоже, связана с тем, что у меня запущен только один главный узел. Когда я запускаю кластер, используя: kops create cluster --zones eu-west-1a ${NAME} --master-size t2.large, поэтому он запускает 1 мастер и 2 узла. Проблема не появляется.

Я не уверен, что является основной причиной проблемы, поскольку ничто не мешает одному узлу иметь внешние тома EBS. Это может быть ошибкой в ​​самом kops, поскольку только один главный узел является скорее исключением, чем правилом.

0 голосов
/ 05 марта 2019

Как видите, к вашему PVC не привязано Volume:, это означает, что произошла ошибка автоматической инициализации тома, и не создан PV, который должен быть создан с вашей конфигурацией динамической инициализации. Вы должны увидеть созданное имя PV в разделе Volume: команды description. К сожалению, нет журналов или событий, которые показывают проблему.

enter image description here

Я бы предложил вам для устранения неполадок создать вручную класс хранения с помощью gp2, чтобы посмотреть, работает ли он с нижеприведенным yaml, а затем определить storageClassName в файле PVC yaml, как показано ниже:

-ручной Класс складирования-gp2.yaml:

apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: gp2-manual
parameters:
  type: gp2
provisioner: kubernetes.io/aws-ebs
reclaimPolicy: Delete
volumeBindingMode: Immediate

Применение:

kubectl apply -f storageclass-manual-gp2.yaml

PV-manual.yaml:

apiVersion: v1
kind: PersistentVolume
metadata:
  name: pv-manual
spec:
  accessModes:
  - ReadWriteOnce
  awsElasticBlockStore:
    fsType: ext4
  capacity:
    storage: 30Gi
  persistentVolumeReclaimPolicy: Delete
  storageClassName: gp2-manual #your new storageclass name

Применение:

kubectl apply -f pv-manual.yaml

Опишите ПВХ:

kubectl describe pvc pvc-gp2-manual

enter image description here

Если ничего не получится, я бы посоветовал вам попробовать другой тип хранения для AWS EBS .

...