如何为 kubernetes 中的软件安装提供持久卷声明

How to provision persistent volume claim for software install in kubernetes

我正在尝试为 k8s 中的 Solr 部署提供 PVC 并将其安装为 /opt/solr,这是默认的 Solr 安装目录。这样,我计划将 Solr 安装及其下的数据都定位到 PVC 上。但是,虽然存储配置得很好并且 statefulset 已创建,但我的部署不起作用,因为 /opt/solr 最终为空。什么是正确的方法?这是我的 deployment.yaml:

apiVersion: apps/v1beta1
kind: StatefulSet
metadata:
  name: solr
  labels:
    app: solr

spec:
  volumeClaimTemplates:
  - metadata:
      name: datadir
      annotations:
        volume.alpha.kubernetes.io/storage-class: slow
    spec:
      accessModes: [ "ReadWriteOnce" ]
      resources:
        requests:
          storage: 2Gi

  serviceName: solr-svc
  replicas: 1
  template:
    metadata:
      labels:
        app: solr
    spec:
      affinity:
        podAntiAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
            - labelSelector:
                matchExpressions:
                  - key: "app"
                    operator: In
                    values:
                    - solr-pool
              topologyKey: "kubernetes.io/hostname"
      terminationGracePeriodSeconds: 300
      containers: 
      - name: solr
        image: solr:6.5.1
        imagePullPolicy: IfNotPresent
        resources:
          requests:
            memory: 512M
            cpu: 500m
        ports:
        - containerPort: 8983
          name: solr-port
          protocol: TCP
        env:
        - name: VERBOSE
          value: "yes"
        command:
        - bash
        - -c
        - "exec /opt/solr/bin/solr start"
        volumeMounts:
        - name: solr-script
          mountPath: /docker-entrypoint-initdb.d/
        - name: datadir
          mountPath: /opt/solr/
      volumes:
        - name: solr-script
          configMap:
            name: solr-configs
      nodeSelector:
        pool: solr-pool

默认情况下,配置的存储空间是空的,并且可能有Deleting配置存储空间的保留策略,请务必检查这些配置。您还可以 exec 到您的 pod 并检查安装的卷并查看它是否正常工作(权限问题,只读文件系统)

在可能的情况下,与使用 /opt/solr 作为 solr 安装位置的 docker 容器配置发生冲突,而我试图在同一位置安装单独的 PV。一旦安装了这个 PV,显然我松开了 solr 安装。对此的修复是:

  • 创建另一个 docker 使用单独位置的图像
  • 更改 solr 配置以使用不同的数据位置
  • 更改 PV 卷位置