Сохраняемость контейнера Jenkins в кластере Kubernetes - PersistentVolumeClaim (VMware / Vsphere)

Попытка сохранить мои задания Дженкинса на хранилище vsphere, когда я удаляю развертывания / службы.

Я пробовал использовать стандартный подход: использовал StorageClass, затем создал PersistentVolumeClaim, на который есть ссылка в файле .ayml, который будет создавать развертывания.

storage-class.yml:

apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: mystorage
provisioner: kubernetes.io/vsphere-volume
parameters:
  diskformat: zeroedthick

постоянный-объем-претензия.yml:

kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: pvc0003
spec:
  storageClassName: mystorage
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 15Gi

jenkins.yml:

---
apiVersion: v1
kind: Service
metadata:
  name: jenkins-auto-ci
  labels:
    app: jenkins-auto-ci
spec:
  type: NodePort
  ports:
  - port: 80
    targetPort: 8080
  selector:
    app: jenkins-auto-ci
---
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: jenkins-auto-ci
spec:
  replicas: 1
  template:
    metadata:
      labels:
        app: jenkins-auto-ci
    spec:
      containers:
      - name: jenkins-auto-ci
        image: jenkins
        resources:
          requests:
            cpu: 100m
            memory: 100Mi
        env:
        - name: GET_HOSTS_FROM
          value: dns
        ports:
        - name: http-port
          containerPort: 80
        - name: jnlp-port
          containerPort: 50000
        volumeMounts:
        - name: jenkins-home
          mountPath: "/var"
      volumes:
        - name: jenkins-home
          persistentVolumeClaim:
            claimName: pvc0003

Я ожидаю, что задания jenkins сохранятся, когда я удалю и воссоздаю развертывания.


person Alias    schedule 04.07.2019    source источник


Ответы (1)


Вы должны создать VMDK, который является диском виртуальной машины.

Это можно сделать с помощью govc, который является vSphere CLI.

govc datastore.disk.create -ds datastore1 -size 2G volumes/myDisk.vmdk

Или с помощью ESXi CLI по ssh на хост как root и выполнив:

vmkfstools -c 2G /vmfs/volumes/datastore1/volumes/myDisk.vmdk

Как только это будет сделано, вы должны создать свой PV, назовем его vsphere_pv.yaml, что может выглядеть следующим образом:

apiVersion: v1
kind: PersistentVolume
metadata:
  name: pv0001
spec:
  capacity:
    storage: 2Gi
  accessModes:
    - ReadWriteOnce
  persistentVolumeReclaimPolicy: Retain
  vsphereVolume:
    volumePath: "[datastore1] volumes/myDisk"
    fsType: ext4

datastore1 в этом примере был создан в корневой папке vCenter, если он у вас находится в другом месте, вам необходимо изменить volumePath. Если он находится в DatastoreCluster, установите volumePath на"[DatastoreCluster/datastore1] volumes/myDisk".

Примените yaml к Kubernetes kubectl apply -f vsphere_pv.yaml

Вы можете проверить, был ли он создан, описав его kubectl describe pv pv0001

Теперь вам нужен PVC, назовем его vsphere_pvc.yaml, чтобы потреблять PV.

kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: pvc0001
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 2Gi

Примените yaml к Kubernetes kubectl apply -f vsphere_pvc.yaml

Вы можете проверить, был ли он создан, описав его kubectl describe pvc pv0001

После этого ваш yaml может выглядеть следующим образом:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: jenkins-auto-ci
spec:
  replicas: 1
  template:
    metadata:
      labels:
        app: jenkins-auto-ci
    spec:
      containers:
      - name: jenkins-auto-ci
        image: jenkins
        resources:
          requests:
            cpu: 100m
            memory: 100Mi
        env:
        - name: GET_HOSTS_FROM
          value: dns
        ports:
        - name: http-port
          containerPort: 80
        - name: jnlp-port
          containerPort: 50000
        volumeMounts:
        - name: jenkins-home
          mountPath: "/var"
      volumes:
        - name: jenkins-home
          persistentVolumeClaim:
            claimName: pvc0001

Все это прекрасно объясняется на Vmware GitHub vsphere-storage-for-kubernetes.

person Crou    schedule 04.07.2019