K8S学习指南(26)-k8s存储对象Persistent Volume

前言

Kubernetes(K8s)是一个强大的容器编排平台,为容器化应用程序提供了许多关键功能,包括持久化存储。在K8s中,Persistent Volume(PV)是一个核心对象,用于抽象和管理集群中的持久化存储资源。本文将深入研究K8s中的Persistent Volume的概念、工作原理,并通过详细的示例演示如何配置和使用Persistent Volume。

什么是Persistent Volume?

在容器化应用中,Pod的生命周期是短暂的,当Pod终止时,其中的数据通常也会被销毁。为了解决这个问题,Kubernetes引入了Persistent Volume(PV)的概念。PV是集群中的一块持久化存储,它独立于Pod存在,可以被多个Pod共享,并且在Pod终止后仍然保留数据。

PV允许开发者将数据存储和Pod解耦,提供了一种灵活且可靠的存储解决方案。PV的生命周期与Pod无关,可以手动配置也可以使用动态存储类(StorageClass)来动态创建。

Persistent Volume的基本结构

PV有一些基本的属性和状态,这些属性决定了PV的可用性和使用方式。

1. Access Modes(访问模式)

PV支持不同的访问模式,它定义了Pod如何与PV进行交互。主要有以下三种访问模式:

  • ReadWriteOnce(RWO): 读写模式,只能被单个Pod挂载为读写模式。
  • ReadOnlyMany(ROX): 只读模式,可以被多个Pod挂载为只读模式。
  • ReadWriteMany(RWX): 读写模式,可以被多个Pod挂载为读写模式。

2. Storage Class(存储类)

Storage Class是一种动态创建PV的机制,它定义了PV的属性,包括存储类型、访问模式等。Storage Class可以根据需求动态地创建PV,使得存储的管理更加灵活。

3. Capacity(容量)

PV的容量定义了可以存储的数据量,以GiB或TiB为单位。Pod可以使用PV上的所有容量,但不会超过PV的限制。

4. Reclaim Policy(回收策略)

Reclaim Policy定义了当PV释放后的行为。主要有以下三种策略:

  • Retain: 保留,PV的数据会被保留,需要手动清理。
  • Recycle: 回收,PV的数据会被清空,重新变为可用状态。
  • Delete: 删除,PV的数据会被删除,PV也会被删除。

Persistent Volume的使用示例

为了更好地理解Persistent Volume的使用,以下是一个详细的示例,涉及PV的手动创建和使用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值