我正在尝试监控 Kubernetes PVC 磁盘使用情况。我需要用于持久卷声明的内存。我找到了命令:
kubectl get --raw /api/v1/persistentvolumeclaims | jq
返回:
"status":{
"phase":"Bound",
"accessModes":[
"ReadWriteOnce"
],
"capacity":{
"storage":"1Gi"
}
}
但它只给我带来了磁盘的全部容量,正如我所说,我需要用过的磁盘
有谁知道哪个命令可以将此信息返回给我?
我没有明确的答案,但希望这对你有帮助。另外,如果有人有更好的答案,我会很感兴趣。
PersistentVolume 子系统为用户和管理员提供了一个 API,可以从存储的使用方式中提取存储的提供方式和使用方式的详细信息。
-- 持久卷 |库伯内特
正如 Kubernetes 文档中所述,PV(PersistentVolume)和 PVC(PersistentVolumeClaim)是对存储的抽象。因此,我认为您不能检查PV或PVC,但您可以检查存储介质。
要获取使用情况,请创建一个将使用您的 PVC 的调试 Pod,从中您可以检查使用情况。这应该取决于您的存储提供商。
# volume-size-debugger.yaml
kind: Pod
apiVersion: v1
metadata:
name: volume-size-debugger
spec:
volumes:
- name: debug-pv
persistentVolumeClaim:
claimName: <pvc-name>
containers:
- name: debugger
image: busybox
command: ["sleep", "3600"]
volumeMounts:
- mountPath: "/data"
name: debug-pv
使用
kubectl apply -f volume-size-debugger.yaml
应用上述清单,并使用 kubectl exec -it volume-size-debugger sh
在其中运行 shell。在 shell 内运行 du -sh
以人类可读的格式获取用法。
我相信您已经注意到,这对于监控来说并不是特别有用。它对于时不时地进行一次性检查可能很有用,但对于监控或磁盘空间不足警报来说则不那么有用。
设置监控的一种方法是拥有一个与我们上面类似的 sidecar pod,并从那里收集我们的指标。 node_exporter就是这样一个例子。
另一种方法是使用CSI(容器存储接口)。我没有使用过 CSI,对它了解不够,无法真正解释更多。但这里有一些相关问题和相关 Kubernetes 文档:
+1 到 touchmarine 的 答案,但是我想稍微扩展一下,并添加我的三分钱。
但它只给我带来了磁盘的全部容量,正如我所说的,我 需要二手的
PVC
是一个抽象,代表“存储请求”,并且不存储磁盘使用等信息。作为更高级别的抽象,它根本不关心其消费者如何使用底层存储。
@touchmarine,而不是使用唯一功能是 Pod
的
sleep
并且每次您需要检查需要手动附加到它的磁盘使用情况时,我建议使用这样的东西:apiVersion: apps/v1
kind: Deployment
metadata:
name: nginx-deployment
labels:
app: nginx
spec:
replicas: 1
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
volumes:
- name: media
persistentVolumeClaim:
claimName: media
containers:
- name: nginx
image: nginx
ports:
- containerPort: 80
volumeMounts:
- mountPath: "/data"
name: media
- name: busybox
image: busybox
command: ["/bin/sh"]
args: ["-c", "while true; do du -sh /data; sleep 10;done"]
volumeMounts:
- mountPath: "/data"
name: media
它当然可以是单个容器
busybox
Pod
,如 @touchmarine 的示例,但在这里我决定还展示它如何用作在单个 nginx
内的 Pod
容器旁边运行的边车.由于它运行一个简单的 bash 脚本 - 一个无限 while 循环,它将当前磁盘使用情况打印到标准输出,可以使用 kubectl logs
读取它,而不需要使用
kubectl exec
并附加到 Pod
:$ kubectl logs nginx-deployment-56bb5c87f6-dqs5h busybox
20.0K /data
20.0K /data
20.0K /data
我想它也可以更有效地用于配置某种磁盘使用情况监控。