volumes

  • 卷(volumes):
  • 1.emptyDir
    • 1.1.emptyDir卷特性:
    • 1.2.官方示例:
    • 1.3.我们做一个实例:
  • 2.HostPath
    • 2.1.HostPath卷特性:
    • 2.2.官方示例:
    • 2.3.我们做一个实例:
  • 3.nfs

卷(volumes):

容器中的文件存在时间是短暂的,当一个容器发生崩溃时,文件会丢失,而容器重新启动后状态却是干净的;而第二个问题时解决了一个Pod中不同容器间共享文件。

卷的类型有很多,详细请查看官方文档:卷

1.emptyDir

1.1.emptyDir卷特性:

当Pod被创建时,emptyDir卷也随之创建,在Pod运行期间,此卷会一直存在。
用于Pod中不同容器间的数据共享。
当 Pod 从节点上删除时,emptyDir 卷中的数据也会被永久删除并不会保存。
emptyDir 卷存储在该节点所使用的介质可以是磁盘或 SSD 或网络存储也可以是内存;注意介质为内存的话会记入容器消耗。

1.2.官方示例:

配置项只有最后三行,相对比较简单。

apiVersion: v1
kind: Pod
metadata:name: test-pd
spec:containers:- image: k8s.gcr.io/test-webservername: test-containervolumeMounts:- mountPath: /cachename: cache-volumevolumes:- name: cache-volumeemptyDir: {}

1.3.我们做一个实例:

第一步:我们创建一个准备用的deploy类型的yaml文件,上面通用部分没贴,主要看我们要用的这部分,创建两个nginx容器,将emptyDir的卷分别挂在两个容器下。

kind: Deployment
metadata:labels:app: dp-nginxname: dp-nginx
spec:replicas: 1selector:matchLabels:app: dp-nginxstrategy: {}template:metadata:labels:app: dp-nginxspec:containers:- image: nginxname: nginxvolumeMounts:- mountPath: /optname: share-volume- image: redisname: redisvolumeMounts:- mountPath: /tmpname: share-volumevolumes:- name: share-volumeemptyDir: {}

第二步:执行yaml文件创建deploy资源

[root@k8s-master01 ~]# kubectl create -f dp-nginx.yaml
deployment.apps/dp-cm created
[root@k8s-master01 ~]# kubectl get deployments.apps
NAME       READY   UP-TO-DATE   AVAILABLE   AGE
dp-nginx   1/1     1            1           17m
[root@k8s-master01 ~]# kubectl get pod
NAME                       READY   STATUS    RESTARTS   AGE
dp-nginx-98db5f6df-6g24r   2/2     Running   0          2m40s

第三步:在nginx容器的/opt目录下创建一个文件,然后再redis容器内成都/tmp目录下查看,看是否共享

# 在nginx容器内创建文件
[root@k8s-master01 ~]# kubectl exec -ti dp-nginx-98db5f6df-6g24r -c nginx -- bash
root@dp-nginx-98db5f6df-6g24r:/# cd /opt/
root@dp-nginx-98db5f6df-6g24r:/opt# touch haha.txt
root@dp-nginx-98db5f6df-6g24r:/opt# ls
haha.txt
# 到redis容器查看是否文件共享
[root@k8s-master01 ~]# kubectl exec -ti dp-nginx-98db5f6df-6g24r -c redis -- ls /tmp
haha.txt

第四步:没有第四步了,从第三步可以看到在nginx容器创建的文件,是可以在redis容器内看到的,所有共享卷是成功的。

2.HostPath

2.1.HostPath卷特性:

hostPath 卷能将主机节点文件系统上的文件或目录挂载到你的 Pod 中。

注意:官方是不推荐使用这种方式的,但是当你需要使用hostPath时,它的范围应仅限于所需的文件或目录,并以只读方式挂载。

2.2.官方示例:

apiVersion: v1
kind: Pod
metadata:name: test-pd
spec:containers:- image: k8s.gcr.io/test-webservername: test-containervolumeMounts:- mountPath: /test-pdname: test-volumevolumes:- name: test-volumehostPath:# 宿主上目录位置path: /data# 此字段为可选type: Directory

hostPath类型支持的type值:

  • 默认为空:意味着在安装 hostPath 卷之前不会执行任何检查。
  • DirectoryOrCreate:如果在给定路径上什么都不存在,那么将根据需要创建空目录,权限设置为 0755,具有与 kubelet 相同的组和属主信息。
  • Directory:在给定路径上必须存在的目录。
  • FileOrCreate:如果在给定路径上什么都不存在,那么将在那里根据需要创建空文件,权限设置为 0644,具有与 kubelet 相同的组和所有权。
  • File:在给定路径上必须存在的文件。
  • Socket:在给定路径上必须存在的 UNIX 套接字。
  • CharDevice:在给定路径上必须存在的字符设备。
  • BlockDevice:BlockDevice

注意: FileOrCreate 模式不会负责创建文件的父目录。 如果欲挂载的文件的父目录不存在,Pod 启动会失败。

2.3.我们做一个实例:

我们的举例是用的File类型,你也可以尝试其他类型,配置方式都一样

第一步:从下面这个例子中可以看到容器内的时区与我们宿主机时区是不一样的

[root@k8s-master01 ~]# kubectl exec -ti dp-nginx-98db5f6df-6g24r -c nginx -- cat /etc/timezone
Etc/UTC
[root@k8s-master01 ~]# cat /etc/timezone
Asia/Shanghai

第二步:修改yaml文件,然后更新deploy副本

    spec:containers:- image: nginxname: nginxvolumeMounts:- mountPath: /optname: share-volume- mountPath: /etc/timezonename: timezone- image: redisname: redisvolumeMounts:- mountPath: /tmpname: share-volumevolumes:- name: share-volumeemptyDir: {}- name: timezonehostPath:path: /etc/timezone  # 宿主机路径type: File# 更新副本,注意大小写,我刚才file写的小写报错了
[root@k8s-master01 ~]# kubectl replace -f dp-nginx.yaml
deployment.apps/dp-nginx replaced

第三步:查看容器时区,是成功的,已经修改为shanghai;可以看到挂载宿主机时区的已经修改,没挂载的redis容器的时区还是默认

[root@k8s-master01 ~]# kubectl exec dp-nginx-7b456ccf45-8c8fn -c nginx -- cat /etc/timezone
Asia/Shanghai
[root@k8s-master01 ~]# kubectl exec dp-nginx-7b456ccf45-8c8fn -c redis -- cat /etc/timezone
Etc/UTC

3.nfs

nfs 卷能将 NFS (网络文件系统) 挂载到你的 Pod 中。 不像 emptyDir 那样会在删除 Pod 的同时也会被删除,nfs 卷的内容在删除 Pod 时会被保存,卷只是被卸载。
但是生产中不大建议使用。

这个实例我没有准备,就说下怎么做吧。有兴趣可以自己做一下。

第一步:准备一台NFS服务器,创建共享目录/data/test
第二步:将nfs的共享目录挂载到Pod中

    spec:containers:- image: nginxname: nginxvolumeMounts:- mountPath: /optname: nfs-volumevolumes:- name: nfs-volumenfs:server: 192.168.10.10  # nfs服务器ippath: /data/test

第三步:创建Pod资源后在容器内部/opt下创建文件,在nfs服务器/data/test下查看是否共享,反过来测试也可以。如果资源共享说明成功。

其他类型的卷可以查看官网,下一篇写pv与pvc!

kubernetes之volumes使用相关推荐

  1. Kubernetes之Volumes

    概述 Volume是对各种存储资源的抽象.虚拟化.为管理.控制.使用存储资源提供统一接口.Openstack中的volume为虚拟机提供存储,Docker中的volume为容器提供存储.因为在kube ...

  2. Docker Kubernetes存储>Volumes配置管理

    Docker Kubernetes存储>Volumes配置管理 1.简介 2. emptyDir卷 2.1 简介 2.2 emptyDir卷示例配置 2.3 文件超过sizelimit 3. h ...

  3. 【译】A Kubernetes quick start for people who know just enough about Docker to get by

    如果你住在我们太阳系的这一侧,你可以保证以前听说过Kubernetes. 你可能不知道究竟是什么. 但那没关系. 即使你以前没有听说过,也要坚持下去并找出答案. 它会达到你的期望. 我保证Kubern ...

  4. s24.基于 Kubernetes v1.25 (二进制) 和 Docker部署高可用集群

    1.安装说明 本文章将演示二进制方式安装高可用k8s 1.17+,相对于其他版本,二进制安装方式并无太大区别,只需要区分每个组件版本的对应关系即可. 生产环境中,建议使用小版本大于5的Kubernet ...

  5. a32.ansible 生产实战案例 -- 基于kubeadm安装kubernetes v1.22 -- 集群部署(一)

    源码下载地址:https://github.com/raymond999999/kubernetes-ansible 1.高可用Kubernetes集群规划 角色 机器名 机器配置 ip地址 安装软件 ...

  6. a24.ansible 生产实战案例 -- 基于kubeadm安装kubernetes v1.20 -- 集群部署(一)

    源码下载地址:https://github.com/raymond999999/kubernetes-ansible 1.高可用Kubernetes集群规划 角色 机器名 机器配置 ip地址 安装软件 ...

  7. Kubernetes 1.5通过Ceph实现有状态容器

    在上一篇博文,我们通过kubernetes的devlopment和service完成了sonarqube的部署.看起来已经可用,但是仍然有一个很大的问题.我们知道,像mysql这种数据库是需要保存数据 ...

  8. 初试 Kubernetes 集群使用 CephFS 文件存储

    目录 Kubernetes PersistentVolumes 介绍 环境.软件准备 单节点使用 CephFS Kubernetes PV & PVC 方式使用 CephFS 测试跨节点使用 ...

  9. s20.基于 Kubernetes v1.25 (kubeadm) 和 Docker 部署高可用集群(二)

    4.4 安装 Docker master和node安装docker-ce: [root@k8s-master01 ~]# cat install_docker.sh #!/bin/bash # #** ...

最新文章

  1. Oracle 变量绑定与变量窥视合集系列二
  2. Only Available on April 1st
  3. 《python数据分析实战》第七章手写
  4. 使用SSMS操作数据-sql
  5. nginx优化-nginx事件处理模型优化use epoll;
  6. 如何运行 SAP Spartacus cypress 端到端测试
  7. Linux命令常用大全
  8. Vue2.0 --- vue-cli脚手架中全局引入JQ
  9. Problem C: 顺序表基本运算(线性表)
  10. 微信表情包小程序源码-更新登录接口+增加举牌功能
  11. [No000014]听说不背单词,考英语会是这种下场-我们为什么必须背单词?
  12. Windows PowerShell 语言快速参考
  13. 计网实验三 虚拟局域网 VLAN
  14. 蓝凌LKS-kOA怎么样?
  15. 代码质量好坏如何评判
  16. TSN之linuxptp交叉编译
  17. 大白菜装机教程win10_电脑一键装机win10系统_win10教程
  18. 搞机:window10安装Linux子系统(WSL)及迁移到非系统盘
  19. 用户名修改后进入不了计算机,我想知道怎么修改后电脑用户名
  20. c++ abs 取绝对值函数

热门文章

  1. linux svn checkout代码shell脚本
  2. 服务器内网可以打开外网打不开怎么办?网站搭建后打不开怎么办?
  3. 宝塔 云服务器 外网无法访问 解决办法
  4. cadence 通孔焊盘_通孔焊盘内走线不报错
  5. 世界经典电影Top 50
  6. ftp服务器连接数修改,ftp服务器连接数设置
  7. 双11狂欢与价值战,苏宁悟空榜给你真实的数据
  8. BI神器Power Query(7)-- PQ从文本文件导入数据(1/2)
  9. MPN (Learning Normal Dynamics in Videos with Meta Prototype Network)代码阅读
  10. java黑马面试_JavaWeb-黑马面面(面试刷题系统)项目实战