kubernetes核心技术之Volume知识点总结

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
可观测可视化 Grafana 版,10个用户账号 1个月
简介: kubernetes核心技术之Volume知识点总结

Volume概述

VolumePod中能够被多个容器访问的共享目录。 KubernetesVolume定义在 Pod 上,它被一个Pod中的多个容 器挂载到具体的文件目录下。 VolumePod的生命周期相同,但与容器的生命周期不相关, 当容器终止或重启时, Volume 中的数据也不会丢失。 要使用volumepod需要指定 volume 的类型和内容(字段) , 和映射到容器的位置(字段) 。Kubernetes 支持多种类型的 Volume,包括: emptyDirhostPathgcePersistentDiskawsElasticBlockStorenfsiscsiflockerglusterfsrbdcephfsgitReposecretpersistentVolumeClaimdownwardAPIazureFileVolumeazureDiskvsphereVolumeQuobytePortworxVolumeScaleIOemptyDirEmptyDir 类型的 volume创建于 pod 被调度到某个宿主机上的时候, 而同一个 pod 内的容器都能读写 EmptyDir 中的同一个文件。 一旦这个 pod离开了这个宿主机, EmptyDir 中的数据就会被永久删除。 所以目前 EmptyDir类型的 volume主要用作临时空间, 比如 Web服务器写日志或者 tmp 文件
需要的临时目录。

EmptyDir

yaml示例如下

apiVersion: v1
kind: Pod
metadata:
   name: mynginx
   labels:
      app: mynginx
spec:
 containers:
   - name: mynginx
     image: reg.harbor.com/public/nginx:latest
     ports:
      - containerPort: 80
     volumeMounts:
     - mountPath: /cache
       name: cache-volume
 volumes:
  - name: cache-volume
    emptyDir: {}

hostPath

HostPath属性的 volume使得对应的容器能够访问当前宿主机上的指定目录。 例如, 需要运行一个访问 Docker系统目录的容器, 那么就使用/var/lib/docker 目录作为一个HostDir类型的 volume; 或者要在一个容器内部运行 CAdvisor, 那么就使用/dev/cgroups目录作为一个 HostDir类型的 volume。 一旦这个 pod 离开了这个宿主机, HostDir中的数据虽然不会被永久删除, 但数据也不会随 pod 迁移到其他宿主机上。 因此, 需要注意的是,由于各个宿主机上的文件系统结构和内容并不一定完全相同, 所以相同 podHostDir 可能会在不 同的宿主机上表现出不同的行为。 yaml示例如下:

apiVersion: v1
kind: Pod
metadata:
   name: mynginx2
   labels:
      app: mynginx2
spec:
 containers:
   - name: mynginx2
     image: reg.harbor.com/public/nginx:latest
     ports:
      - containerPort: 80
     volumeMounts:
     - mountPath: /test-pd
       name: test-volume
 volumes:
  - name: test-volume
    hostPath:
       path: /data

NFS

NFS 类型 volume。 允许一块现有的网络硬盘在同一个 pod内的容器间共享。 yaml 示例如下:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: mynginx3
spec:
  replicas: 2
  selector:
    matchLabels:
      app: mynginx3
  template:
    metadata:
      labels:
        app: mynginx3
    spec:
      containers:
      - image: reg.harbor.com/public/nginx:1.18.0
        name: mynginx3
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 80
        volumeMounts:
        - name: html
          mountPath: /usr/share/nginx/html/
      volumes:
      - name: html
        nfs:
          path: /nfs/data
          server: 10.91.74.201


相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
2天前
|
Kubernetes 调度 Docker
深入探讨容器编排技术:从Docker到Kubernetes
容器编排在现代IT中日益关键,从Docker到Kubernetes,助力应用的自动化部署和扩展。Docker提供容器技术,打包应用及环境为镜像,通过引擎、镜像、容器、网络和存储组件实现隔离运行。Kubernetes作为高级容器编排平台,管理Pod(多容器集合),其核心包括API服务器、控制器管理器、调度器和Kubelet。Kubernetes集群由Master和Worker节点构成,实现Pod的高效调度和运行。
52 6
|
1天前
|
存储 Kubernetes 监控
使用Kubernetes进行容器编排:技术详解与实践
【5月更文挑战第16天】Kubernetes,简称K8s,是开源容器编排系统,用于自动化部署、扩展和管理容器化应用。核心概念包括节点、Pod(最小部署单元)、服务、标签和副本集。其特点有高可用性、可扩展性、自动化和可移植性。实践使用涉及安装配置集群、编写YAML部署清单、应用部署、监控管理和扩展更新。Kubernetes帮助提升应用的可用性、可扩展性和可移植性。
|
2天前
|
Kubernetes Java 调度
Java容器技术:Docker与Kubernetes
Java容器技术:Docker与Kubernetes
22 0
|
2天前
|
JSON Kubernetes API
kubernetes核心技术之ConfigMap知识点总结
kubernetes核心技术之ConfigMap知识点总结
25 0
|
2天前
|
Kubernetes 网络协议 调度
kubernetes核心技术之探针知识总结
kubernetes核心技术之探针知识总结
20 0
|
2天前
|
存储 Kubernetes API
kubernetes核心技术之PV与PVC知识总结
kubernetes核心技术之PV与PVC知识总结
61 1
|
2天前
|
Kubernetes 网络协议 应用服务中间件
kubernetes核心技术之Service知识点总结
kubernetes核心技术之Service知识点总结
21 0
|
2天前
|
运维 Kubernetes 容灾
kubernetes核心技术之Controller控制器知识总结
kubernetes核心技术之Controller控制器知识总结
19 1
|
2天前
|
Kubernetes 应用服务中间件 Docker
Kubernetes学习-集群搭建篇(二) 部署Node服务,启动JNI网络插件
Kubernetes学习-集群搭建篇(二) 部署Node服务,启动JNI网络插件
|
1天前
|
存储 Java Serverless
ACK One Argo 工作流集群:玩转容器对象存储
ACK One Argo 工作流集群:玩转容器对象存储
ACK One Argo 工作流集群:玩转容器对象存储