zoukankan      html  css  js  c++  java
  • 28-PV&PVC

    Persistent Volume Claim(PVC)和 Persistent Volume(PV)

    持久卷声明和持久卷

    Pod绑定PVCPVC绑定PV,达到Pod绑定使用PV的目的;

    PV是全局的,属于Cluster,没有命名空间;

    Deployment不认识PVC模板;只有StatefulSet才会编号PVC

    环境上可能有成千上万个PVC,这就意味着运维人员需要去创建PV。手工是不可能的;

    所以有了Storage Class,作为创建PV的模板;

    Pod——PVC——Storage Class——PV

    PVC 可以理解为持久化存储的“接口”,它提供了对某种持久化存储的描述,但不提供具体的实现;而这个持久化存储的实现部分则由 PV 负责完成。

    容器持久化存储,总结一下整体流程。

    【用户提交请求创建pod,Kubernetes发现这个pod声明使用了PVC,那就靠PersistentVolumeController帮它找一个PV配对。

    没有现成的PV,就去找对应的StorageClass,帮它新创建一个PV,然后和PVC完成绑定。

    新创建的PV,还只是一个API 对象,需要经过“两阶段处理”变成宿主机上的“持久化 Volume”才真正有用:
    第一阶段由运行在master上的AttachDetachController负责,为这个PV完成 Attach 操作,为宿主机挂载远程磁盘;
    第二阶段是运行在每个节点上kubelet组件的内部,把第一步attach的远程磁盘 mount 到宿主机目录。这个控制循环叫VolumeManagerReconciler,运行在独立的Goroutine,不会阻塞kubelet主循环。

    完成这两步,PV对应的“持久化 Volume”就准备好了,POD可以正常启动,将“持久化 Volume”挂载在容器内指定的路径。】

    PV的存储模式有:

    1、ReadWriteOnce——可以被单个节点以读/写方式挂载;

    2、ReadOnlyMany——可以被多个节点以只读方式挂载;

    3、ReadWriteMany——可以被多个节点以读/写方式挂载;

     

    卷的几种状态:

    1、Bound(已绑定)——卷已经被声明绑定

    2、Available(可用)——一块空闲资源还没有被任何声明绑定

    3、Released(已释放)——声明被删除,但是资源还未被集群重新声明

    4、Failed(失败)——该卷的自动回收失败

     

    本地持久化存储:Local Persistent Volume

    用户希望 Kubernetes 能够直接使用宿主机上的本地磁盘目录,而不依赖于远程存储服务,来提供“持久化”的容器 Volume。

     

    1、Local Persistent Volume 并不适用于所有应用

    2、其次,相比于正常的 PV,一旦这些节点宕机且不能恢复时,Local Persistent Volume 的数据就可能丢失。这就要求使用 Local Persistent Volume 的应用必须具备数据备份和恢复的能力

     

    第一个难点:如何把本地磁盘抽象成 PV?

    1、你绝不应该把一个宿主机上的目录当作 PV 使用

    2、一个 Local Persistent Volume 对应的存储介质,一定是一块额外挂载在宿主机的磁盘或者块设备

     

     

    第二个难点:调度器如何保证 Pod 始终能被正确地调度到它所请求的 Local Persistent Volume 所在的节点上呢?

    1、在调度的时候考虑 Volume 分布:

    对于 Local PV 来说,节点上可供使用的磁盘(或者块设备),必须是运维人员提前准备好的

     

     

    StorageClass的一个字段:

    volumeBindingMode=WaitForFirstConsumer——延迟绑定,推迟到调度的时候(Pod已经进入调度器)

     

    当你提交了 PV 和 PVC 的 YAML 文件之后,Kubernetes 就会根据它们俩的属性,以及它们指定的 StorageClass 来进行绑定。只有绑定成功后,Pod 才能通过声明这个 PVC 来使用对应的 PV。

    如果你使用的是 Local Persistent Volume 的话,就会发现,这个流程根本行不通。

    人生的路还很长,继续走吧
  • 相关阅读:
    技术分享的一些好的建议
    项目经理排期的几个tip
    公司的目标和你的目标的关系
    Android实现双击事件的两种方式
    互联网公司团队建设的几个要点
    一对一还是一对多? MVP设计前提
    互联网产品研发的典型流程
    架构和模式的区别:三层架构和MVC在应用开发中的位置
    Android Studio插件:PlantUML
    Android Studio插件:GsonFromat
  • 原文地址:https://www.cnblogs.com/jinggs/p/14949368.html
Copyright © 2011-2022 走看看