【kubernetes】PVC

简介: 【kubernetes】PVC

一、创建 PVC


PVC 作为用户对存储资源的需求申请,主要涉及存储空间请求、访问模式、PV 选择条件和存储类别等信息的设置。


上示例(申请 8GiB 存储空间,访问模式为 ReadOnlyMany,存储类别为“directpv-min-io”):


cat >test-direct-pvc.yaml  <<EOF
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: testqijingpvc
  namespace: default
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 100Mi
  storageClassName: direct-csi-min-io
EOF


创建:

[root@k8s0 test_persistent_volume]# kubectl create -f test-direct-pvc.yaml 
persistentvolumeclaim/testqijingpvc created


验证:

[root@k8s0 test_persistent_volume]# kubectl get pvc                        
NAME                               STATUS    VOLUME                                     CAPACITY   ACCESS MODES   STORAGECLASS        AGE
mongo-persistent-storage-mongo-0   Bound     pvc-cb9e0f2f-a5d2-4281-aa14-9881a8f7ef67   100Gi      RWO            direct-csi-min-io   9d
mongo-persistent-storage-mongo-1   Bound     pvc-51a693a3-a1cc-4e7e-97de-eb8c9162ac63   100Gi      RWO            direct-csi-min-io   9d
mongo-persistent-storage-mongo-2   Bound     pvc-3c6fa343-a13e-4fc3-93a8-8826a60405ba   100Gi      RWO            direct-csi-min-io   9d
testpvc                            Bound     pvc-3e802a9e-ab1b-46cc-829d-e5d107cb4308   100Mi      RWO            direct-csi-min-io   10m
testqijingpvc                      Pending                                                                        direct-csi-min-io   3s

image.png




二、Pod 使用 PVC


在PVC 创建成功之后,Pod 就可以以存储卷(Volume)的方式使用 PVC 的存储资源了。PVC 受限于命名空间,Pod 在使用 PVC 时,必须与 PVC 处于同一个命名空间。


Kubernetes 为 Pod 挂载 PVC 的过程如下:系统在 Pod 所在的命名空间中找到其配置的 PVC,然后找到 PVC 绑定的后端 PV,将 PV 存储挂载到 Pod,将 PV 存储挂载到 Pod 所在的 Node 的目录下,最后将 Node 的目录挂载到 Pod 的容器内。


在 Pod 中使用 PVC 时,需要在 YAML 配置中设置 PVC 类型的 Volume,然后在容器中通过 volumeMounts.mountPath 设置容器内的挂载目录,示例如下:


[root@k8s0 test_persistent_volume]# cat > test-qijing-pod.yaml <<EOF
apiVersion: v1
kind: Pod
metadata:
  name: qijing-test-pod
spec:
  containers:
  - name: myfronted
    image: nginx
    volumeMounts:
    - mountPath: "/var/www/html"
      name: qijingpd
  volumes:
    - name: qijingpd
      persistentVolumeClaim:
        claimName: testqijingpvc 
EOF


创建:

[root@k8s0 test_persistent_volume]# kubectl create -f test-qijing-pod.yaml 
pod/qijing-test-pod created


验证:

pod/qijing-test-pod created
[root@k8s0 test_persistent_volume]# kubectl get po
NAME                                     READY   STATUS             RESTARTS         AGE
qijing-test-pod                          1/1     Running            0                18s

进入容器内部执行:df -h

image.png

可以看到指定的目录确实挂载了一个盘,验证成功。


相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
JSON Kubernetes Shell
【Azure K8S | AKS】在不丢失文件/不影响POD运行的情况下增加PVC的大小
【Azure K8S | AKS】在不丢失文件/不影响POD运行的情况下增加PVC的大小
187 0
|
Kubernetes Shell Perl
【Azure K8S|AKS】进入AKS的POD中查看文件,例如PVC Volume Mounts使用情况
【Azure K8S|AKS】进入AKS的POD中查看文件,例如PVC Volume Mounts使用情况
200 0
|
存储 Kubernetes Go
【Azure K8S | AKS】在AKS集群中创建 PVC(PersistentVolumeClaim)和 PV(PersistentVolume) 示例
【Azure K8S | AKS】在AKS集群中创建 PVC(PersistentVolumeClaim)和 PV(PersistentVolume) 示例
177 0
|
9月前
|
存储 Kubernetes 安全
k8s存储类型:emptyDir、hostPath、nfs、pvc及存储类storageclass的静态/动态创建pv
Kubernetes提供了多种存储类型,满足不同的应用需求。`emptyDir`和 `hostPath`适用于临时和宿主机存储需求,`nfs`适用于共享存储,`PersistentVolumeClaim`和 `StorageClass`实现了持久存储的灵活管理。通过理解和配置这些存储类型,可以有效提升Kubernetes集群的存储管理能力。
364 13
|
存储 Kubernetes API
在K8S中,PVC创建和挂载失败原因有哪些?
在K8S中,PVC创建和挂载失败原因有哪些?
|
存储 Kubernetes 测试技术
k8s使用pvc,pv,sc关联ceph集群
文章介绍了如何在Kubernetes中使用PersistentVolumeClaim (PVC)、PersistentVolume (PV) 和StorageClass (SC) 来关联Ceph集群,包括创建Ceph镜像、配置访问密钥、删除默认存储类、编写和应用资源清单、创建资源以及进行访问测试的步骤。同时,还提供了如何使用RBD动态存储类来关联Ceph集群的指南。
413 7
|
存储 Kubernetes 调度
在K8S中,什么是PV和PVC?
在K8S中,什么是PV和PVC?
|
存储 缓存 Kubernetes
在K8S中,有状态服务与无状态服务都是怎么使用pv和pvc?(可以通过应用场景说明一下)
在K8S中,有状态服务与无状态服务都是怎么使用pv和pvc?(可以通过应用场景说明一下)
|
Kubernetes 关系型数据库 MySQL
k8s练习--通过NFS+PV+PVC+POD,部署一个MySQL服务,并将MySQL的数据进行持久化存储
本文档介绍了如何使用Kubernetes (K8s)、NFS、PersistentVolume (PV)、PersistentVolumeClaim (PVC)和Pod来部署并实现MySQL服务的数据持久化存储。Kubernetes是一个用于自动化部署、扩展和管理容器化应用的强大平台。NFS作为一种网络文件系统协议,能够使Kubernetes集群中的Pod跨节点访问共享文件。PV和PVC机制则提供了持久化的存储解决方案,确保数据即使在Pod生命周期结束后仍得以保留。
786 0
|
存储 Kubernetes 调度
在k8S中,PV和PVC如何使用?
在k8S中,PV和PVC如何使用?

热门文章

最新文章