Kubernetes Minikube с локальным постоянным хранилищем

В настоящее время я пытаюсь развернуть следующее на Minikube. Я использовал файлы конфигурации, чтобы использовать путь к хосту в качестве постоянного хранилища на узле minikube.

apiVersion: v1
kind: PersistentVolume
metadata:
  name: "pv-volume"
spec:
  capacity:
    storage: "20Gi"
  accessModes:
    - "ReadWriteOnce"
  hostPath:
    path: /data
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: "orientdb-pv-claim"
spec:
  accessModes:
    - "ReadWriteOnce"
  resources:
    requests:
      storage: "20Gi"
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: orientdbservice 
spec:
  #replicas: 1
  template:
    metadata:
     name: orientdbservice
     labels:
       run: orientdbservice
       test: orientdbservice
    spec:
      containers:
        - name: orientdbservice
          image: orientdb:latest
          env:
           - name: ORIENTDB_ROOT_PASSWORD
             value: "rootpwd"
          ports:
          - containerPort: 2480
            name: orientdb
          volumeMounts:
          - name: orientdb-config
            mountPath: /data/orientdb/config
          - name: orientdb-databases
            mountPath: /data/orientdb/databases 
          - name: orientdb-backup
            mountPath: /data/orientdb/backup
      volumes:
          - name: orientdb-config
            persistentVolumeClaim:
              claimName: orientdb-pv-claim
          - name: orientdb-databases
            persistentVolumeClaim:
              claimName: orientdb-pv-claim
          - name: orientdb-backup
            persistentVolumeClaim:
              claimName: orientdb-pv-claim
---
apiVersion: v1
kind: Service
metadata:
  name: orientdbservice
  labels:
    run: orientdbservice
spec:
  type: NodePort
  selector:
    run: orientdbservice
  ports:
   - protocol: TCP
     port: 2480
     name: http

что приводит к следующему

#kubectl get pv
NAME                                       CAPACITY   ACCESSMODES   RECLAIMPOLICY   STATUS      CLAIM                       STORAGECLASS   REASON    AGE
pv-volume                                  20Gi       RWO           Retain          Available                                                        4h
pvc-cd14d593-78fc-11e7-a46d-1277ec3dd2b5   20Gi       RWO           Delete          Bound       default/orientdb-pv-claim   standard                 4h
#kubectl get pvc
NAME                STATUS    VOLUME                                     CAPACITY   ACCESSMODES   STORAGECLASS   AGE
orientdb-pv-claim   Bound     pvc-cd14d593-78fc-11e7-a46d-1277ec3dd2b5   20Gi       RWO 
#kubectl get svc
NAME              CLUSTER-IP   EXTERNAL-IP   PORT(S)          AGE
orientdbservice   10.0.0.16    <nodes>       2480:30552/TCP   4h
#kubectl get pods
NAME                              READY     STATUS              RESTARTS   AGE
orientdbservice-458328598-zsmw5   0/1       ContainerCreating   0          4h
#kubectl describe pod orientdbservice-458328598-zsmw5
Events:
  FirstSeen LastSeen    Count   From            SubObjectPath   TypeReason      Message
  --------- --------    -----   ----            -------------   --------    ------      -------
  4h        1m      37  kubelet, minikube           Warning     FailedMount Unable to mount volumes for pod "orientdbservice-458328598-zsmw5_default(392b1298-78ff-11e7-a46d-1277ec3dd2b5)": timeout expired waiting for volumes to attach/mount for pod "default"/"orientdbservice-458328598-zsmw5". list of unattached/unmounted volumes=[orientdb-databases]
  4h        1m      37  kubelet, minikube           Warning     FailedSync  Error syncing pod

Я вижу следующую ошибку

Unable to mount volumes for pod,timeout expired waiting for volumes to attach/mount for pod

Есть ли что-то неправильное в том, как я создаю постоянный том и PersistentVolumeClaim на моем узле.

minikube version: v0.20.0

Цените всю помощь


person user3812069    schedule 04.08.2017    source источник


Ответы (2)


Ваша конфигурация в порядке.

Протестировано под minikube v0.24.0, minikube v0.25.0 и minikube v0.26.1 без проблем.

Имейте в виду, что minikube находится в активной разработке, и, особенно если вы находитесь под Windows, это похоже на экспериментальное программное обеспечение.

Установите более новую версию minikube и повторно разверните ее. Это должно решить проблему.

Вы можете проверить наличие обновлений с помощью команды minikube update-check, которая даст примерно такой результат:

$ minikube update-check
CurrentVersion: v0.25.0
LatestVersion: v0.26.1

Чтобы обновить minikube, просто введите minikube delete, который удалит вашу текущую установку minikube, и загрузите новую версию, как описано.

$ minikube delete
There is a newer version of minikube available (v0.26.1).  Download it here:
https://github.com/kubernetes/minikube/releases/tag/v0.26.1

To disable this notification, run the following:
minikube config set WantUpdateNotification false
Deleting local Kubernetes cluster...
Machine deleted.
person Ivan Beldad    schedule 20.04.2018

Для somereason инициатор provisioner: k8s.io/minikube-hostpath в minikube не работает.

So:

  • удалить класс хранения по умолчанию kubectl delete storageclass standard
  • создать следующий класс хранения:
    
    apiVersion: storage.k8s.io/v1
    kind: StorageClass
    metadata:
      name: standard
    provisioner: docker.io/hostpath
    reclaimPolicy: Retain
    
  • Также при монтировании томов у вас есть один PVC, привязанный к одному PV, поэтому вместо нескольких томов просто используйте один том и монтируйте их с разными подкаталогами, что создаст три подкаталога (backup, config & databases) в каталоге /data вашего хоста:


apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: orientdbservice
spec:
  #replicas: 1
  template:
    metadata:
     name: orientdbservice
     labels:
       run: orientdbservice
       test: orientdbservice
    spec:
      containers:
        - name: orientdbservice
          image: orientdb:latest
          env:
           - name: ORIENTDB_ROOT_PASSWORD
             value: "rootpwd"
          ports:
          - containerPort: 2480
            name: orientdb
          volumeMounts:
          - name: orientdb
            mountPath: /data/orientdb/config
            subPath: config
          - name: orientdb
            mountPath: /data/orientdb/databases
            subPath: databases
          - name: orientdb
            mountPath: /data/orientdb/backup
            subPath: backup
      volumes:
          - name: orientdb
            persistentVolumeClaim:
              claimName: orientdb-pv-claim 
- Теперь разверните свой yaml: kubectl create -f yourorientdb.yaml

person bits    schedule 20.04.2018
comment
Почему мне нужно удалить стандартный класс хранения? Почему бы просто не создать еще один StorageClass с другим именем? - person august0490; 07.04.2021