一、什么是PV和PVC?

PV的全称是Persistent Volume,翻译过来为持久化存储卷,是对底层的共享存储的一种抽象,PV由管理员进行创建和配置,主要含存储能力、访问模式、存储类型、回收策略、后端存储类型等主要信息,它和具体的底层的共享存储技术的实现方式有关,比如NFS、Hostpath、RBD等。

PVC的全称是: PersistenVolumeClaim (持久化卷声明),PVC是用户存储的一种声明,PVC和Pod类似,Pod是消耗节点node资源,PVC消耗的是PV资源,Pod可以请求CPU的内存,而PVC可以请求特定的存储空间和访问模式。

二、PV和PVC的使用场景

 配图来自K8S权威指南第四版

存储工程师把分布式存储系统上的总空间划分成一个一个小的存储块,K8S的集群管理员将存储块和PV进行一一对应,用户通过PVC对对存储进行申请,比如可以指定具体容量的大小,访问模式或者存储类型,这样的好处是用户不需要关心底层的存储实现细节,只需要直接申请使用PVC即可,若申请的PVC所对应的PV不能满足用户的要求,不会生效,直到有合适的PV生成,PVC会自动与PV完成绑定,存储工程师、K8S管理员,用户之间业务解耦,灵活性更强。

三、创建PV

PV支持多种不同类型的存储,如:NFS、hostpath、RBD、ICCSI,本文以hostpath为例介绍如何创建PV

第一步:现在宿主机data目录下data/pod/volume1,volume1将作为PV对应的hostpath本地存储的目录

第二步:通过yaml文件创建PV

 [root@k8s-master zhanglei]# cat pv-hostpath.yaml
kind: PersistentVolume #指定为PV类型
apiVersion: v1
metadata:
name: pv-statefulset #指定PV的名称
labels: #指定PV的标签
release: stable
spec:
capacity:
storage: .1Gi #指定PV的容量
accessModes:
- ReadWriteOnce #指定PV的访问模式,简写为RWO,只支持挂在1个Pod的读和写
persistentVolumeReclaimPolicy: Recycle #指定PV的回收策略,Recycle表示支持回收,回收完成后支持再次利用
hostPath: #指定PV的存储类型,本文是以hostpath为例
path: /data/pod/volume1 #指定PV对应后端存储hostpath的目录

说明:

accessModes支持多种访问模式

1)ReadWriteOnce(RWO):读写权限,但是只支持挂载在1个Pod

2)ReadOnlyMany(ROX):只读权限,支持挂载在多个Pod

3)ReadWriteMany(RW):读写权限,支持挂载在多个Pod上

persistentVolumeReclaimPolicy的策略,指的是如果PVC被释放掉后,PV的处理,这里所说的释放,指的是用户删除PVC后,与PVC对应的PV会被释放掉,PVC个PV是一一对应的关系

1)Retain,PV的数据不会清理,会保留volume,如果需要清理,需要手动进行

2)Recycle,会将数据进行清理,即 rm -rf /thevolume/*(只有 NFS 和 HostPath 支持),清理完成后,PV会呈available状态,支持再次的bound

3)Delete,删除存储资源,会删除PV及后端的存储资源,比如删除 AWS EBS 卷(只有 AWS EBS, GCE PD, Azure Disk 和 Cinder 支持)

四、创建PVC

[root@k8s-master zhanglei]# cat pvc-hostpath.yaml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: mppvc-01 # 指定PVC的名称
namespace: default
spec:
accessModes: ["ReadWriteOnce"] # 指定PVC的访问模式
resources:
requests:
storage: .05Gi # PVC申请的容量

说明:

1)PVC声明了accessModes访问类型为ReadWriteOnce,创建后,系统会自动去找能够支持ReadWriteOnce访问类型的PV,若无符合条件的PV,则不会进行绑定,

2)PVC声明了storage的大小为0.05Gi,创建后,系统会自动去找能够支持此容量的PV,通常PV的容量至少要大于或者等于0.05Gi才会去进行绑定

从这里来看,对于用户来说,即只需要声明访问类型、容量、另外还可通过StorageClass声明具体的PV类型即可完成对持久化存储卷的申请,而不需要去维护和关注后端存储

五、查询PV和PVC的

经过前面的步骤我们创建了PV和PVC,现在来看下两者是否已经完成了绑定,在PV的创建已经指定了其名称为pv-statefulset,PVC的名称为mppvc-01

[root@k8s-master zhanglei]# kubectl get pv |grep pv-statefulset
pv-statefulset 107374182400m RWO Recycle Bound default/mppvc-
[root@k8s-master zhanglei]# kubectl get pvc |grep mppvc-
mppvc- Bound pv-statefulset 107374182400m RWO 13d

可以看到pv-statefulset这个PV已经和mppvc-01的PVC进行了绑定(Bound),RWO和Recycle也是之前PV和PVC声明的状态,说明绑定成功


[root@k8s-master zhanglei]# kubectl describe pv pv-statefulset
Name: pv-statefulset
Labels: release=stable
Annotations: pv.kubernetes.io/bound-by-controller: yes
Finalizers: [kubernetes.io/pv-protection]
StorageClass:
Status: Bound
Claim: default/mppvc-
Reclaim Policy: Recycle
Access Modes: RWO
VolumeMode: Filesystem
Capacity: 107374182400m
Node Affinity: <none>
Message:
Source:
Type: HostPath (bare host directory volume)
Path: /data/pod/volume1
HostPathType:
Events: <none>
[root@k8s-master zhanglei]# kubectl describe pvc mppvc-
Name: mppvc-
Namespace: default
StorageClass:
Status: Bound
Volume: pv-statefulset
Labels: <none>
Annotations: pv.kubernetes.io/bind-completed: yes
pv.kubernetes.io/bound-by-controller: yes
Finalizers: [kubernetes.io/pvc-protection]
Capacity: 107374182400m
Access Modes: RWO
VolumeMode: Filesystem
Mounted By: <none>
Events: <none>

再来看下PV的详细(describe)信息,可以看到type是hostpath类型,且会显示在数据卷在宿主机的/data/pod/volume1的目录下。

六、总结

创建PV个PVC分为二步:

第一步:创建PV,支持自定义不同的存储大小和访问模式(RWX,RWO)、存放路径、后端服务server(如hostpath、或NAS盘的数据盘的挂载点)

第二步:创建PVC,绑定到PV。创建PVC的时候可以指定PVC的request storage,即申请的存储的容量,会根据申请的storage和访问模式自动匹配符合要求的PV

创建完PV和PVC主要是为了使用它来达到实现持久化存储的目的,如何进行使用请看与statufulset有关的文章,谢谢阅读~

K8S-PV和PVC的实践的更多相关文章

  1. 【k8s】k8s pv、pvc无法删除问题。

    一般删除步骤为:先删除pod再删除pvc最后删除pv 遇到的问题 但是遇到pv使用处于"Terminating"状态,而且删不掉.如下图: 解决办法 直接删除k8s中的记录: ku ...

  2. K8s PV and PVC and StorageClass

    PVC和PV之间没有依靠ID.名称或者label匹配,而是靠容量和访问模式,PVC的容量和访问模式需要是某个PV的子集才能自动匹配上.注意:PVC和PV是一对一的,也即一个PV被一个PVC自动匹配后, ...

  3. K8S 使用NFS 创建PV和PVC的例子 学习From https://blog.csdn.net/xts_huangxin/article/details/51494472

    1. 获取资料 网址: https://blog.csdn.net/xts_huangxin/article/details/51494472  感谢原作者 这里面 按照自己的机器情况进行了学习模仿 ...

  4. Kubernetes PV/PVC使用实践

    转载于https://www.cnblogs.com/ericnie/p/7733281.html   pv,pvc的概念不解释了,之前在registry中已经使用过PV和PVC,现在想把WebLog ...

  5. k8s的pv和pvc简述

    pvc:资源需要指定:1.accessMode:访问模型:对象列表:    ReadWriteOnce – the volume can be mounted as read-write by a s ...

  6. 容器编排系统K8s之PV、PVC、SC资源

    前文我们聊到了k8s中给Pod添加存储卷相关话题,回顾请参考:https://www.cnblogs.com/qiuhom-1874/p/14180752.html:今天我们来聊一下持久存储卷相关话题 ...

  7. 4.k8s存储之Volume、PV、PVC和StatefulSet

    3.Volume 容器磁盘上的文件的生命周期是短暂的,这就使得在容器中运行重要应用时会出现一些问题.首先,当容器崩溃时,kubelet 会重启它,但是容器中的文件将丢失--容器以干净的状态(镜像最初的 ...

  8. k8s之PV、PVC、StorageClass详解

    导读 上一篇写了共享存储的概述以及一个简单的案例演示.这一篇就写一下PV和PVC. PV是对底层网络共享存储的抽象,将共享存储定义为一种"资源",比如Node也是容器应用可以消费的 ...

  9. 7.2 k8s 基于PV、PVC搭建zookeeper 3节点集群

    1.PV,PVC介绍 1.1.StorageClass & PV & PVC关系图 Volumes 是最基础的存储抽象,其支持多种类型,包括本地存储.NFS.FC以及众多的云存储,我们 ...

  10. k8s之PV、PVC

    目录 一.PVC和PV 1.1 PV概念 1.2 PVC概念 1.3 PV与PVC之间的关系 1.4 两种PV的提供方式 二.基于nfs创建静态PV资源和PVC资源 2.1 配置nfs存储(192.1 ...

随机推荐

  1. 2018-08-27 jq筛选选择器

    筛选选择器:为了辅助选择器更简便.快速的找到元素: 1.过滤 eq(n) -> 第n个元素(从零开始) $('h1').eq(2) // 第三个h1 first() -> 第一个元素 la ...

  2. 数据源管理 | OLAP查询引擎,ClickHouse集群化管理

    本文源码:GitHub·点这里 || GitEE·点这里 一.列式库简介 ClickHouse是俄罗斯的Yandex公司于2016年开源的列式存储数据库(DBMS),主要用于OLAP在线分析处理查询, ...

  3. flex布局学习总结--阮一峰

    基本概念:   采用 Flex 布局的元素,称为 Flex 容器(flex container),简称"容器".它的所有子元素自动成为容器成员,称为 Flex 项目(flex it ...

  4. lb的keepalive问题

    lb的keepalive问题 0. keepalive 大家都很清楚他的用意了,就是为了减少3次握手,设置一个timeout,比如说20s ,在20s内不请求,连接还是保持着,这时候请求过来,不需要重 ...

  5. 微信小程序var和let以及const有什么区别

    微信小程序var和let以及const的区别: 在JavaScript中有三种声明变量的方式:var.let.const. var:声明全局变量,换句话理解就是,声明在for循环中的变量,跳出for循 ...

  6. GeoServer2.17与Jetty9在Windows上的最佳安装实践

    1 JDK的选择 我使用了adopted openjdk8.0.252,安装简便,只需添加2个环境变量(JAVA_HOME,JRE_HOME)即可. 我的安装路径: C:\SDKs\adoptopen ...

  7. 【Java_SSM】(四)Eclipse中通过maven引入jar包

    这篇博文我们介绍一下如何通过eclipse配置setting并引入jar包 (1)eclipse:Window--Preferences--Maven--User Setting 全部完成后点Appl ...

  8. 十、理解JavaBean

    1. 理解Bean 1.JavaBean本身就是一个类,属于Java的面向对象编程. 2.在JSP中如果要应用JSP提供的Javabean的标签来操作简单类的话,则此类必须满足如下的开发要求: (1) ...

  9. 存储层技术:JDBC、Hibernate、Mybatis三者之间的比较学习

    JDBC     Hibernate Mybatis    (Java  DataBase Connnection) 是通过JAVA访问数据库 对JDBC的轻量封装 像操作对象操作数据库 对SQL的轻 ...

  10. Git常用目录

    Git常用目录 // 初始化Git仓库 $ git init // 将代码添加到暂存区中 $ git add . // 将代码保存到仓库中 $ git commit -m "保存的说明&qu ...