kubernetes资源对象存储类

本文围绕Kubernetes资源对象存储类展开,介绍了存储类资源对象,如Volume的多种类型及用途,还阐述了动态存储管理机制,包括PV、StorageClass和PVC。此外,讲解了Kubernetes的安全类内容,涉及ServiceAccount身份认证、RBAC访问控制权限系统以及NetworkPolicy网络策略。

kubernetes资源对象存储类

存储类

存储类的资源对象主要包括 Volume、Persistent Volume、PVC 和 StorageClass。

  首先看看基础的存储类资源对象——Volume(存储卷)。

  Volume 是 Pod 中能够被多个容器访问的共享目录。Kubernetes 中的 Volume 概念、用途和目的与 Docker 中的 Volume 比较类似,但二者不能等价。首先, Kubernetes 中的 Volume 被定义在 Pod 上,被一个 Pod 里的多个容器挂载到具体的文件目录下;其次,Kubernetes中的 Volume 与 Pod 的生命周期相同,但与容器的生命周期不相关,当容器终止或者重启时,Volume 中的数据也不会丢失;最后,Kubernetes 支持多种类型的 Volume,例如 GlusterFS、Ceph 等分布式文件系统。

  Volume 的使用也比较简单,在大多数情况下,我们先在 Pod 上声明一个 Volume,然后在容器里引用该 Volume 并将其挂载(Mount)到容器里的某个目录下。举例来说,若我们要给之前的 Tomcat Pod 增加一个名为 datavol 的 Volume,并将其挂载到容器的 /mydata-data 目录下,则只对 Pod 的定义文件做如下修正即可(代码中的粗体部门);

template:
  metadata:
    labels:
      app: app-demo
      tier: frontend
  spec:
    volumes:
    - name: datavol
      emptyDir: {
   
   }
    containers:
    - name: tomcat-demo
    image: tomcat
    volumeMounts:
    - mountPath: /mydata-data
      name: datavol
    imagePullPolicy: IfNotPresent

  Kubernetes 提供了非常丰富的 Volume 类型供容器使用,例如临时目录、宿主机目录、共享存储等,下面对其中一些常见的类型进行说明。

1. emptyDir

   一个 emptyDir 是在 Pod 分配到 Node 时创建的。从它的名称就可以看出,它的初始内容为空,并且无须指定宿主机上对应的目录文件,因为这是 Kubernetes 自动分配的一个目录,当 Pod 从 Node 上移除时,emptyDir 中的数据也被永久移除。emptyDir 的一些用途如下。

  • 临时空间,例如用于某些应用程序运行时,所需的临时目录,且无须永久保留。
  • 长时间任务执行过程中使用的临时目录。
  • 一个容器需要从另一个容器中获取数据的目录(多容器共享目录)。

  在默认情况下,emptyDir 使用的是节点的存储介质,例如磁盘或者网络存储

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值