Kubernetes进阶之hostpath及emptyDir数据卷
admin
2023-03-10 17:21:13
0

K8s进阶之数据卷与数据持久卷
目录:

一 从外部访问应用最佳方式 
二 配置管理 
三 数据卷与数据持久卷 
四 再谈有状态应用部署 
五 K8S 安全机制

三、数据卷与数据持久卷
数据卷产生的背景
为什么有数据卷,这里的数据卷和docker的数据卷还不太一样,实现的机制不是一套,数据卷说白了就是能帮助你持久化你pod重要的数据,如果你不持久化的话,pod删除里面临时产生的数据也会被删除,这不管是k8s中还是docker中,这都是一样的,所以k8s和docker都提供了这种volume的这种相关功能,就是为了持久化你容器中的数据,能让它重建或者删除,数据依然存在。

• Kubernetes中的Volume提供了在容器中挂载外部存储的能力 ,也就是部署k8s自身的存储了,就好比自己搭建一个分布式存储,好比公有云的云盘存储,这样是可以挂在集群之外的存储可以挂在k8s中去使用。
pod要想使用这种存储必须定义两点:
• Pod需要设置卷来源(spec.volume)和挂载点(spec.containers.volumeMounts)两个信息后才可以使用相应的Volume

来看一下卷的类型最好的解释就是官方:
来看一下官方怎么说的:
https://kubernetes.io/docs/concepts/storage/volumes/
Kubernetes进阶之hostpath及emptyDir数据卷
第一种就是本地卷
像hostPath类型与docker里面的bind mount类型,就是直接挂载到宿主机文件的类型
像emptyDir是这样本地卷,也就是类似于volume类型
这两点都是绑定node节点的

第二种就是网络数据卷
比如Nfs、ClusterFs、Ceph,这些都是外部的存储都可以挂载到k8s上

第三种就是云盘
比如AWS、微软(azuredisk)

第四种就是k8s自身的资源
比如secret、configmap、downwardAPI

先来看一下本地卷
像emptyDir类似与docker的volume,而docker删除容器,数据卷还会存在,而emptyDir删除容器,数据卷也会丢失,一般这个只做临时数据卷来使用

创建一个空卷,挂载到Pod中的容器。Pod删除该卷也会被删除。
应用场景:Pod中容器之间数据共享
emptyDir类型

[root@k8s-master demo]# vim emptydir.yaml
apiVersion: v1
kind: Pod
metadata:
  name: my-pod
spec:
  containers:
  - name: write
    image: centos
    command: ["bash","-c","for i in {1..100};do echo 
$i >> /data/hello;sleep 1;done"]
    volumeMounts:
      - name: data
        mountPath: /data
  - name: read
    image: centos
    command: ["bash","-c","tail -f /data/hello"]
    volumeMounts:
      - name: data
        mountPath: /data
  volumes:
  - name: data
    emptyDir: {}

[root@k8s-master demo]# kubectl create -f emptydir.yaml 

[root@k8s-master demo]# kubectl get pod
NAME                     READY   STATUS      RESTARTS   AGE
my-pod                   2/2     Running     13         67m
mypod                    1/1     Running     0          3h40m
mypod2                   1/1     Running     0          3h34m
mypod3                   0/1     Completed   0          3h6m
mypod4                   0/1     Completed   0          3h
nginx-5ddcc6cb74-lplxl   1/1     Running     0          4h8m
[root@k8s-master demo]# kubectl logs my-pod read

Hostpath类型

挂载Node文件系统上文件或者目录到Pod中的容器。
应用场景:Pod中容器需要访问宿主机文件

[root@k8s-master demo]# vim hostpath.yaml 
apiVersion: v1
kind: Pod
metadata:
  name: my-pod2
spec:
  containers:
  - name: busybox
    image: busybox
    args:
    - /bin/sh
    - -c - sleep 36000
    volumeMounts:
    - name: data
      mountPath: /data
  volumes:
  - name: data
    hostPath:
      path: /tmp
      type: Directory
[root@k8s-master demo]# kubectl create -f hostpath.yaml 
[root@k8s-master demo]# kubectl get pod
NAME                     READY   STATUS      RESTARTS   AGE
my-pod2                  1/1     Running     0          12s
mypod                    1/1     Running     0          4h53m
mypod2                   1/1     Running     0          4h47m
mypod3                   0/1     Completed   0          4h27m
mypod4                   0/1     Completed   0          4h22m
nginx-5ddcc6cb74-lplxl   1/1     Running     0          5h30m
web-67fcf9bf8-mrlhd      1/1     Running     0          20m

[root@k8s-master demo]# kubectl exec -it my-pod2 sh
cd /data/
ls

这里创建的数据和我们被分配的node节点的数据都是一样的,创建的数据都会更新上去,删除容器,不会删除数据卷的数据。

相关内容

热门资讯

终于了解“新金龙炸/金/花开挂... 网上科普关于“新金龙炸/金/花有没有挂”话题很是火热,小编也是针对新金龙炸/金/花作*弊开挂的方法以...
【第一资讯】“钱潮十三水辅助器... 您好:钱潮十三水这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游...
百位科学家推荐的“启蒙书单” 美国《华盛顿邮报》12月23日文章,原题:改变一百位科学家职业生涯的儿童读物 孩子们出生时,笔者就决...
今日重大发现“宝宝吃吃吃有挂吗... 网上科普关于“宝宝吃吃吃有没有挂”话题很是火热,小编也是针对宝宝吃吃吃作*弊开挂的方法以及开挂对应的...
今日重大发现“开心联盟有没有挂... 家人们!今天小编来为大家解答开心联盟透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买很...
终于懂了“新西游到底有挂吗?”... 终于懂了“新西游到底有挂吗?”(详细开挂教程)您好,新西游这个游戏其实有挂的,确实是有挂的,需要了解...
重磅消息“同乡游究竟有挂吗?”... 网上科普关于“同乡游有没有挂”话题很是火热,小编也是针对同乡游作*弊开挂的方法以及开挂对应的知识点,...
今日重大通报“西域棋牌有没有挂... 有 亲,根据资深记者爆料西域棋牌是可以开挂的,确实有挂(咨询软件无需打开...
【第一财经】“越记乡游辅助器?... 【第一财经】“越记乡游辅助器?”(透视曝光猫腻)您好,越记乡游这个游戏其实有挂的,确实是有挂的,需要...
最新引进“新三哥玩十三张究竟有... 家人们!今天小编来为大家解答新三哥玩十三张透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪...