k8s教程(Volume篇)-PV详解

article/2025/6/21 8:23:30

文章目录

  • 01 引言
  • 02 PV详解
    • 2.1 示例配置详解
      • 2.1.1 存储容量 (Capacity)
      • 2.1.2 存储卷模式 (Volume Modes)
      • 2.1.3 访问模式 (Access Modes)
      • 2.1.4 存储类别(Class)
      • 2.1.5 回收策略 (Reclaim Policy)
      • 2.1.6 挂载选项 (Mount Options)
      • 2.1.6 节点亲和性 (Node Affinity)
  • 03 文末

01 引言

声明:本文为《Kubernetes权威指南:从Docker到Kubernetes实践全接触(第5版)》的读书笔记

在上一篇博客《k8s教程(Volume篇)-持久卷工作原理》,我们了解了持久卷的工作原理,本文继续深入学习PV。

02 PV详解

PV作为对存储资源的定义,主要涉及存储能力、访问模式、存储类型、回收策略、后端存储类型等关键信息的设置。

Kubernetes支持的PV类型如下:

类型描述
AWSElasticBlockStoreAWS公有云提供的Elastic Block Store
AzureFileAzure公有云提供的File
AzureDiskAzure公有云提供的Disk
CephFS一种开源共享存储系统
CinderOpenStack块存储系统
FC (Fibre Channel)光纤存储设备
FlexVolume一种插件式的存储机制
Flocker一种开源共享存储系统
GCEPersistentDiskGCE公有云提供的Persistent Disk
Glusterfs一种开源共享存储系统
HostPath宿主机目录,仅用于单机测试
iSCSIiSCSI存储设备
Local本地存储设备,从Kubernetes 1.7版本开始引入,到1.14版本时达到稳定版本,目前可以通过指定块设备(Block Device) 提供Local PV,或通过社区开发的sig-storage-local-static-provisioner插件管理Local PV的生命周期
NFS网络文件系统
Portworx VolumesPortworx提供的存储服务
Quobyte VolumesQuobyte提供的存储服务
RBD (Ceph Block Device)Ceph块存储
ScaleIO VolumesDellEMC的存储设备
StorageOSStorageOS提供的存储服务
VsphereVolumeVMWare提供的存储系统

2.1 示例配置详解

下面的示例声明的PV具有如下属性:5GiB存储空间,存储卷模式为 Filesystem,访问模式为ReadWriteOnce,存储类型为slow(要求在系统中己存在名称为“slow”的StorageClass),回收策略为Recycle,并且后端存储类型为nfs (设置了 NFS ServerIP地址和路径),同时设置了挂载选项 (mountOptions)

apiVersion: v1
kind: PersistentVolume
metadata:name: pv1
spec:capacity:Storage: 5GivolumeMode: Filesystem accessModes:- ReadwriteOncepersistentVolumeReclaimPolicy: RecyclestorageClassName: slow mountoptions:- hard- nfsvers=4.1nfs:path: /tmpserver: 172.17.0.2

PV资源对象需要设置的关键配置参数如下:

2.1.1 存储容量 (Capacity)

描述存储的容量,目前仅支持对存储空间的设置 (storage=xx),未来可能加入IOPS、吞吐率等设置。

2.1.2 存储卷模式 (Volume Modes)

可以设置的选项包括Filesystem(文件系统,默认值)和Block(块设备):

  • 文件系统模式的PV将以目录(Directory)形式挂载到Pod内;
  • 块设备,如果设备是空的,Kubernetes则会自动在块设备上创建一个文件系统。支持块设备的存储类型会以裸设备 (Raw Block Device) 的形式挂载到容器内,并且不会创建任何文件系统,适用于需要直接操作裸设备(速度最快)的应用程序。

目前有以下PV类型支持裸块设备类型:AWSElasticBlockStore AzureDisk、 FC ( Fibre Channel ) 、 GCEPersistentDisk isCsI Local volume、 OpenStack Cinder、 RBD (Ceph Block Device) VsphereVolume

下面的示例使用了块设备的PV定义:

apiVersion: v1
kind: PersistentVolume 
metadata:name: block-pv
spec:capacity:storage: 10Gi accessModes:- ReadWriteOncepersistentVolumeReclaimPolicy: RetainvolumeMode: Blockfd:targetWWNs: ["50060e801049cfd1"] lun: 0readonly: false

2.1.3 访问模式 (Access Modes)

PV存储卷在挂载到宿主机系统上时,可以设置不同的访问模式 (Access Modes。PV支持哪些访问模式由存储提供商提供支持,例如NFS可以支持多个客户端同时读写(ReadWriteMany)模式,但一个特定的NFS PV也可以以只读(Read-only)模式导出到服务器上。

Kubernetes支持的访问模式如下:

  • ReadWriteOnce (RWO):读写权限,并且只能被单个Node挂载;
  • ReadOnlyMany (ROX):只读权限,允许被多个Node挂载;
  • ReadWriteMany(RWX):读写权限,允许被多个Node挂载。

某些PV可能支持多种访问模式,但PV在挂载时只能使用一种访问模式,多种访问模式不能同时生效。
在这里插入图片描述

2.1.4 存储类别(Class)

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

2.1.5 回收策略 (Reclaim Policy)

通过PV定义中的persistentVolumeReclaimPolicy字段进行设置,可选项如下:

  • Retain保留数据,需要手工处理
  • Recycle简单清除文件的操作(例如运行rm -rf /thevolume/*命令),只有 NFS 和 HostPath 两种类型的 PV支持 Recycle 策略。
  • DeletePV相连的后端存储完成Volume的删除操作,AWSElasticBlockStore、 GCEPersistentDis、 AzureDisk和Cinder类型的PV支持 Delete策略。

2.1.6 挂载选项 (Mount Options)

在将PV挂载到一个Node上时,根据后端存储的特点,可能需要设置额外的挂载选项的参数,这个可以在PV定义中的mountOptions字段进行设置。

下面的例子为对一个类型为gcePersistentDiskPV设置挂载选项的参数:

apiVersion: "V1"
kind: "PersistentVolume" 
metadata:name: gce-disk-1 
spec:capacity:storage: "10Gi" accessModes:- "ReadwriteOnce" mountoptions:- hard- nolock- nfsvers=3gcePersistentDisk:fsType: "ext4"pdName: "gce-disk-1"

目前,以下PV类型支持设置挂载选项:AWSElasticBlockStore AzureDisk、 AzureFile、 CephFS、 Cinder ( OpenStack block storage) GCEPersistentDisk、 Glusterfs、 NFS、 Quobyte Volumes、 RBD ( Ceph Block Device)、 StorageOS、 VsphereVolume、 iSCSI

注意Kubernetes不会对挂载选项进行验证,如果设置了错误的挂载选项, 则挂载将会失败

2.1.6 节点亲和性 (Node Affinity)

PV可以设置节点亲和性来限制只能通过某些Node访问Volume,可以在PV定义的nodeAffinity字段中进行设置。使用这些Volume的Pod将被调度到满足条件的 Node上

公有云提供的存储卷(如:AWSElasticBlockStore、GCEPersistentDisk、 AzureDisk等)都由公有云自动完成节点亲和性设置,无须用户手工设置。

对于 Local类型的PV,需要手工设置,例如:

apiVersion: v1
kind: PersistentVolume 
metadata:name: example-local-pv 
spec:capacity:storage: 5Gi accessModes:- ReadwriteOncepersistentVolumeReclaimPolicy: Delete storageclassName: local-storage 1ocal:path: /mnt/disks/ssalnodeAffinity:required:nodeSelectorTerms:- matchExpressions:- key: kubernetes.io/hostname operator: In values:- my-node

某个PV在生命周期中可能处于以下4个阶段(Phase)之一:

  • Available:可用状态,还未与某个PVC绑定;
  • Bound:已与某个PVC绑定;
  • Released:与之绑定的PVC已被删除,但未完成资源回收,不能被其他 PVC使用;
  • Failed:自动资源回收失败。

在定义了PV资源之后,就需要通过定义PVC来使用PV资源了。

03 文末

本文主要讲解了PV的一些概念以及配置详解,希望能帮助到大家,谢谢大家的阅读,本文完!


http://chatgpt.dhexx.cn/article/gWTtekdG.shtml

相关文章

K8s 初学者入门教程

Kubernetes 简称为 K8s 文章目录 写在前面1. 什么是 K8s1.1 K8s 解决了什么问题?1.2 容器编排工具提供了哪些特性? 2. K8s 组件2.1 Node & Pod2.2 Service & Ingress2.3 ConfigMap & Secret2.4 Volumes2.5 Deployment & StatefulSet 3.总结参考 写…

K8s集群搭建教程

学习并总结一下使用三台虚拟机搭建一个kubernetes集群的过程。 目录 一、环境规划二、环境准备2.1 搭建流程概述:2.2 安装环境准备2.2.1 升级系统内核2.2.2 设置主机名和hosts本地解析2.2.3 关闭防火墙和SELinux2.2.4 时间同步2.2.5 关闭 swap 分区2.2.6 将桥接的IP…

k8s教程(Volume篇)-总结

文章目录 01 引言02 内容整理2.1 概念2.2 PV2.3 PVC2.4 StorageClass2.5 CSI 03 文末 01 引言 至此,volume的相关知识已经讲解完了,下面是相关文章的详情总结: 《k8s教程(Volume篇)-k8s存储机制概述》《k8s教程&…

【K8S教程分享】Kubernetes K8S高级视频教程

Kubernetes K8S高级视频教程,目前的云计算(PaaS),事实上已经以K8S为标准建立平台,各大开源项目也都依据K8S对接进行开发或二次开发,所以K8S是目前云计算领域的必备技能,当能结合openstackk8s双平台者的运维、开发、使用者&#xf…

k8s教程(基础篇)-安装与配置概述

文章目录 01 系统要求02 安装概述03 私有镜像库配置与升级3.1 私有镜像库配置3.2 升级 04 CRI(容器运行时接口)详解 4.1 CRI 概述 4.2 CRI 的主要组件 4.3 Pod 和容器的生命周期管理 4.4 面向容器级别的设计思路 4.5 尝试使用新的 Docker-CRI 来创建容器…

K8S入门教程

目录 1.Kubernetes概述 1.1 Kubernetes介绍 1.2 基本架构与常用术语 2.Kubernetes集群 2.1 环境准备与规划 2.2 Master安装 2.3 Node1安装 2.4 Node2安装 2.5 健康检查与示例测试 1.Kubernetes概述 1.1 Kubernetes介绍 1.1.1 Kubernetes是什么及作用 Kubernetes(K8S)是Google在…

k8s教程(基础篇)-入门及案例

文章目录 1. 了解 Kubernetes 1.1 Kubernetes是什么 1.2 Kubernetes的基本知识 1.2.1 Service 1.2.2 Pod 2. 为什么要用 Kubernetes 3. 从一个简单的例子开始 3.1 启动 MySQL 服务 3.1.1 Deployment定义文件 3.1.2 service定义文件 3.2 启动 Tomcat应用 3.2.1 Deployment定义文…

k8s搭建(超详细,保姆级教程)

1、简介 这里就不赘述,想要了解的朋友直接去这里深入了解什么是K8S。 2、环境要求 2台以上机器,操作系统 CentOS7.7-64位系统硬件配置:2GB或更多RAM,2个CPU或更多CPU,硬盘30GB或更多集群中所有机器之间网络互通可以…

k8s教程----零基础快速入门

k8s详解教程----零基础快速入门 前言: Kubernetes(k8s)作为云原生的核心平台,吸引了越来越多的运维、开发、测试以及其他技术员去了解学习。随着行业越来越内卷,k8s已经被广泛使用,作为一名运维人员&#…

K8S使用教程(详细)

Kubernetes详细教程 1. Kubernetes介绍 1.1 应用部署方式演变 在部署应用程序的方式上,主要经历了三个时代: 传统部署:互联网早期,会直接将应用程序部署在物理机上 优点:简单,不需要其它技术的参与 缺点…

零基础学kubernetes(k8s)必看教程,带你10分钟快速实战入门k8s

一、前言 作为一个工作十余年,拥有比较丰富的计算机网络运维、主机运维、云计算平台运维、自动化运维开发经验的老鸟,我来说说我当初刚接触Kubernetes时的一些感受以及学习技巧。 刚开始学习k8s时,我觉得挺难的,一头雾水&#x…

python input函数换行_python input函数换行_python_input函数

Python raw_input() 函数 Python内置函数 python raw_input()用来获取控制台的输入。 raw_input()将所有输入作为字符串看待,返回字符串类型。注意:input()和 raw_input()这两个函 Python input和print函数 - 箬笠蓑衣 258x256 - 5KB - PNG python row函数_row函数_python row_…

Python基础之input函数和eval函数

Python基础之&#xff08;二&#xff09; 一、 input()函数-数据输入 input()函数的功能&#xff1a;显示用户输入的值 input()函数可以包含一些提示性文字 通过使用input()函数&#xff0c;可以使用户主动输入的内容变成程序中的字符串变量的值 <字符串变量> input(&l…

函数input()讲解

目录 上次我们讲解了函数print&#xff0c;今天我们来讲它的“好兄弟”input&#xff01; 讲解 1.input与变量 2.input与提示语 3.input与print 例子 上次我们讲解了函数print&#xff0c;今天我们来讲它的“好兄弟”input&#xff01; 讲解 1.input与变量 input在pyth…

Python input函数

input()函数 import timeprint(亲爱的同学&#xff1a;) time.sleep(1)print(我们愉快地通知您&#xff0c;您已获准在霍格沃茨魔法学校就读。) time.sleep(2)print(随信附上所需书籍及装备一览。) time.sleep(1)print(学期定于九月一日开始。) time.sleep(1)print(鉴于您对魔…

python中input函数最简单详细的了解

一、input&#xff08;&#xff09;函数 有了 输入 魔法&#xff0c;程序就有了对话的功能。计算机根据你的回答进行对应的处理&#xff0c;好像能听懂你的话一样。 你通过 Python 代码向计算机提供指令&#xff0c;计算机执行指令&#xff0c;然后通过 input() 函数把问题显…

input函数和int函数的使用

第一&#xff0c;input函数接受一个标准输入数据&#xff0c;返回str类型 第二&#xff0c;int函数可以把str强制转换为整形 第三&#xff0c;int(input()) ps&#xff1a;最近搞深度学习的视频&#xff0c;但是依然需要实操

python中input函数的使用

input() 函数接受一个标准输入数据&#xff0c;返回为 string 类型。 input() # 单个输入使用input ninput() print(n) print(type(n))ninput("输入&#xff1a;") print(n) print(type(n))ninput() print(n) print(type(n))input().split() split()方法通过指定分…

python编程 input输入函数

作者简介&#xff1a;一名在校计算机学生、每天分享Python的学习经验、和学习笔记。 座右铭&#xff1a;低头赶路&#xff0c;敬事如仪 个人主页&#xff1a;网络豆的主页​​​​​​ 目录 前言 一.输入与输出 1.input输入函数 2注意点① 3注意点② 二.input输入函…

Python中的input()函数

选择题 请问在Python 3.x中&#xff0c;从键盘输入数字2之后&#xff0c;下列代码的输出结果是&#xff1f; a input("请输入年龄&#xff1a;") print(a 1) A a 1 B 2 1 C 3 D 抛出异常 问题解析 1.在Python中&#xff0c;使用内置函数input()可以接收用户的键盘…