如何为 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 卷位置
我正在尝试为 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 卷位置