zoukankan      html  css  js  c++  java
  • Kubernetes进阶实战读书笔记:持久化存储卷(pv详解)

    一、Pod存储卷、PVC、PV及存储设备的调用关系

    二、PV对存储系统的支持可通过插件来实现、目前Kubernetes支持如下类型的插件

    GCEPersistentDisk
    AWSElasticBlockStore
    AzureFile
    AzureDisk
    CSI
    FC (Fibre Channel)
    FlexVolume
    Flocker
    NFS
    iSCSI
    RBD (Ceph Block Device)
    CephFS
    Cinder (OpenStack block storage)
    Glusterfs
    VsphereVolume
    Quobyte Volumes
    HostPath (Single node testing only -- local storage is not supported in any way and WILL NOT WORK in a multi-node cluster)
    Portworx Volumes
    ScaleIO Volumes
    StorageOS

    三、PersistentVolume Spec通用字段详解

    1、存储能力(Capacity)

    Generally, a PV will have a specific storage capacity. This is set using the PV's capacity attribute. See the Kubernetes Resource Model to understand the units expected by capacity.
    #当前pv的容量;目前Capacity仅支持空间设定
    
    Currently, storage size is the only resource that can be set or requested. Future attributes may include IOPS, throughput, etc.
    #将来应该还可以指定IOPS和throughput

    2、存储卷模式(Volume Mode)

    FEATURE STATE: Kubernetes v1.18 [stable]
    Kubernetes supports two volumeModes of PersistentVolumes: Filesystem and Block.
    
    volumeMode is an optional API parameter. Filesystem is the default mode used when volumeMode parameter is omitted.
    
    A volume with volumeMode: Filesystem is mounted into Pods into a directory. If the volume is backed by a block device and the device is empty, Kuberneretes creates a filesystem on the device before mounting it for the first time.
    
    You can set the value of volumeMode to Block to use a volume as a raw block device. Such volume is presented into a Pod as a block device, without any filesystem on it. This mode is useful to provide a Pod the fastest possible way to access a volume, without any filesystem layer between the Pod and the volume. On the other hand, the application running in the Pod must know how to handle a raw block device. See Raw Block Volume Support for an example on how to use a volume with volumeMode: Block in a Pod
    #卷模型、用于指定此卷可被用作文件系统还是裸格式的块设备;默认为Filesysyem

    3、存储类别(Class)

    PV可以设定其存储的类别,通过storageClassName参数指定一个StorageClass资源对象的名称。具有特定类别的PV只能与请求了该类别的PVC进行绑定。未设定类别的PV则只能与不请求任何类别的PVC进行绑定

    4、回收策略(Reclaim Policy)

    Current reclaim policies are:
    #pv空间被释放时的处理机制;可用类型仅为Retain、Recycle、Delete
    
    Retain -- manual reclamation   #保持不动、由管理员随后手动回收
    Recycle -- basic scrub (rm -rf /thevolume/*)  #空间回收、即删除存储卷目录下的所有文件(包含子目录和隐藏文件)、目前仅NFS和hostPath支持此操作
    Delete -- associated storage asset such as AWS EBS, GCE PD, Azure Disk, or OpenStack Cinder volume is deleted #删除存储卷、仅部分云端存储系统支持、如AWS EBS、GCE PD、Azure Disk和Cinder
    Currently, only NFS and HostPath support recycling. AWS EBS, GCE PD, Azure Disk, and Cinder volumes support deletion

    目前,只有NFS和HostPath两种类型的存储支持Recycle策略;AWS EBS、GCE PD、Azure Disk和Cinder volumes支持Delete策略。

    5、挂载参数(Mount Options)

    目前,以下PV类型支持设置挂载参数:

    AWSElasticBlockStore
    AzureDisk
    AzureFile
    CephFS
    Cinder (OpenStack block storage)
    GCEPersistentDisk
    Glusterfs
    NFS
    Quobyte Volumes
    RBD (Ceph Block Device)
    StorageOS
    VsphereVolume
    iSCSI

    四、PersistentVolume Spec访问模式(Access Modes)详解

    1、访问模式(Access Modes)

    A PersistentVolume can be mounted on a host in any way supported by the resource provider. As shown in the table below, providers will have different capabilities and each PV's access modes are set to the specific modes supported by that particular volume. For example, NFS can support multiple read/write clients, but a specific NFS PV might be exported on the server as read-only. Each PV gets its own set of access modes describing that specific PV's capabilities.
    尽管在pv层看起来并无差别,但存储设备支持及启动的功能特性却可能不尽相同。例如NFS存储支持多客户端同时挂在及读写操作、但也可能是在共享时仅启用了只读操作,但也可能是在共享时仅启用了指读操作、其他存储系统也存在类似的可配置特性、因此PV顶层的设备或许存在其特有的访问模式,用户使用时必须在其特性范围内设定其功能,具有同如图7所示
    
    The access modes are:
    ReadWriteOnce -- the volume can be mounted as read-write by a single node #仅可被单节点读写挂载
    ReadOnlyMany -- the volume can be mounted read-only by many nodes         #可被多个节点同时只读挂载
    ReadWriteMany -- the volume can be mounted as read-write by many nodes    #可被多个节点同时读写挂载
    In the CLI, the access modes are abbreviated to:
    
    RWO - ReadWriteOnce  #命令行可简写为RWO
    ROX - ReadOnlyMany   #命令行可简写为ROX
    RWX - ReadWriteMany  #命令行可简写为RWX
    

    2、个PV支持的访问模式

      

    四、创建pv

    1、NFS示例模板

    [root@master chapter7]# cat pv-nfs-0001.yaml 
    apiVersion: v1
    kind: PersistentVolume
    metadata:
      name: pv-nfs-0001
      labels:
        release: stable
    spec:
      capacity:
        storage: 5Gi
      volumeMode: Filesystem
      accessModes:
        - ReadWriteMany
      persistentVolumeReclaimPolicy: Recycle
      storageClassName: slow
      mountOptions:
        - hard
        - nfsvers=4.1
      nfs:
        path:  "/webdata/htdocs"
        server: nfs.ikubernetes.io

    2、创建状态查看

    [root@master chapter7]# kubectl apply -f pv-nfs-0001.yaml 
    persistentvolume/pv-nfs-0001 created
    [root@master chapter7]# kubectl get pv
    NAME          CAPACITY   ACCESS MODES   RECLAIM POLICY   STATUS      CLAIM   STORAGECLASS   REASON   AGE
    pv-nfs-0001   5Gi        RWX            Recycle          Available           slow                    19s
    [root@master chapter7]# kubectl get pv pv-nfs-0001 -o custom-columns=NAME:metadata.name,STATUS:status.phase
    NAME          STATUS
    pv-nfs-0001   Available
    

    3、rbd存储后端示例模板

    [root@master chapter7]# cat pv-rbd-0001.yaml 
    apiVersion: v1
    kind: PersistentVolume
    metadata:
      name: pv-rbd-0001
      labels:
        release: "stable"
    spec:
      capacity:
        storage: 2Gi
      accessModes:
        - ReadWriteOnce
      storageClassName: fast
      rbd:
        monitors:
          - 172.16.0.56:6789
          - 172.16.0.57:6789
          - 172.16.0.58:6789
        pool: kube
        image: pv-rbd-0001
        user: admin
        secretRef:
          name: ceph-secret
        fsType: ext4
        readOnly: false
      persistentVolumeReclaimPolicy: Retain

    创建运行

    [root@master chapter7]# kubectl apply -f pv-rbd-0001.yaml 
    persistentvolume/pv-rbd-0001 configured
    [root@master chapter7]# kubectl get pv
    NAME          CAPACITY   ACCESS MODES   RECLAIM POLICY   STATUS   CLAIM                  STORAGECLASS   REASON   AGE
    pv-nfs-0001   5Gi        RWX            Recycle          Bound    default/pvc-nfs-0001   slow                    14h
    pv-rbd-0001   2Gi        RWO            Retain           Bound    default/pvc-rbd-0001   fast                    3m58s

    4、PV空间被释放时的处理机制

    A volume will be in one of the following phases:
    
    Available -- a free resource that is not yet bound to a claim                                   #可用状态,还未与某个PVC绑定
    Bound -- the volume is bound to a claim                                                         #已与某个PVC绑定
    Released -- the claim has been deleted, but the resource is not yet reclaimed by the cluster    #绑定的PVC已经删除,资源已释放,但没有被集群回收。
    Failed -- the volume has failed its automatic reclamation                                       #因自动资源回收失败而处于的故障状态
    
    The CLI will show the name of the PVC bound to the PV
     
  • 相关阅读:
    C# Winform窗体间传值
    用遍历判断listview是否有重复数据
    asp.net中Webservice的调用实例
    C#中datagridview获取当前行并修改数据
    C#ArrayList的用法
    八步解决ACCESS自动编号问题,SERVER 2000数据库,转换为ACCESS数据库
    SQL Server 2005 中为安装程序增加计数器注册表项值
    我现在在用的.NET数据操作类
    C#中MessageBox用法大全
    C#调用WebService实例和开发
  • 原文地址:https://www.cnblogs.com/luoahong/p/13508651.html
Copyright © 2011-2022 走看看