k8s基础中如何通过Volume保持数据持久
admin
2023-04-04 22:22:33
0

     一个运行中的容器对文件系统的写入都是发生在其分层文件系统的可写层。一旦容器运行结束,所有写入都会被丢弃。如果数据需要长期存储,那就需要对容器数据做持久化支持。

   Kubernetes 和 Docker 类似,也是通过 Volume 的方式提供对存储的支持。Volume 被定义在 Pod 上,可以被 Pod 里的多个容器挂载到相同或不同的路径下。          Kubernetes 中 Volume 的 概念与Docker 中的 Volume 类似,但不完全相同。具体区别如下:

    Kubernetes 中的 Volume 与 Pod 的生命周期相同,但与容器的生命周期不相关。当容器终止或重启时,Volume 中的数据也不会丢失。

当 Pod 被删除时,Volume 才会被清理。并且数据是否丢失取决于 Volume 的具体类型,比如:emptyDir 类型的 Volume 数据会丢失,而 PV 类型的数据则不会丢失。

Kubernetes 目前支持多种 Volume 类型,大致如下:

emptyDir

nfs

hostPath

gitRepo

persistentVolumeClaim

projected

portworxVolume

等等

下面对常见的做一下基本介绍

emptryDir

    如果Pod配置了EmpyDir数据卷,在Pod的生命周期内都会存在,当Pod被分配到 Node上的时候,会在Node上创建EmptyDir数据卷,并挂载到Pod的容器中。只要Pod 存在,EmpyDir数据卷都会存在(容器删除不会导致EmpyDir数据卷丟失数据),但是如果Pod的生命周期终结(Pod被删除),EmpyDir数据卷也会被删除,并且永久丢失。

示例演示:

apiVersion: v1
kind: Pod
metadata:
  name: test-pod2
spec:
 containers:
 - image: busybox
   name: test-emptydir2
   command: ["sleep","90"]
   volumeMounts:
   - mountPath: /data2
     name: data-volume2
 volumes:
 - name: data-volume2
   emptyDir: {}

 kubectl create -f emptyDir2.yaml

kubectl describe  test-pod2

k8s基础中如何通过Volume保持数据持久

k8s基础中如何通过Volume保持数据持久

k8s 集群会在 node 节点上  创建EmptyDir数据卷

/var/lib/kubelet/pods/61691e55-6740-11e9-b7fc-0050569360ba/volumes/kubernetes.io~empty-dir/data-volume2

k8s基础中如何通过Volume保持数据持久

在k8s-node1 上添加文件 

k8s基础中如何通过Volume保持数据持久

进入pod 容器中查看

k8s基础中如何通过Volume保持数据持久

删除pod 

kubectl delete -f emptyDir2.yaml

k8s-node1 临时目录就会被删除

进入原来的目录,临时目录已经被删除

k8s基础中如何通过Volume保持数据持久

hostPath

hostPath类型则是映射node文件系统中的文件或者目录到pod里。在使用hostPath类型的存储卷时,也可以设置type字段,支持的类型有文件、目录、File、Socket、CharDevice和BlockDevice。

apiVersion: v1
kind: Pod
metadata:
  name: test-pod2
spec:
  containers:
  - image: busybox
    name: test-hostpath
    command: [ "sleep", "3600" ]
    volumeMounts:
    - mountPath: /test-data
      name: test-volume
  volumes:
  - name: test-volume
    hostPath:
      path: /data
      type: Directory

kubectl create -f host_path.yaml

k8s基础中如何通过Volume保持数据持久

k8s基础中如何通过Volume保持数据持久

进入挂载的/test-data目录中,创建个测试文件

k8s基础中如何通过Volume保持数据持久

创建测试文件

k8s基础中如何通过Volume保持数据持久

在pod  运行的节点上查看

k8s基础中如何通过Volume保持数据持久

ps 在node 节点的目录里创建,容器里面也会自动生成

 删除 pod  容器  kubectl delete -f host_path.yaml

查看 node 节点上的 文件还在

k8s基础中如何通过Volume保持数据持久

相关内容

热门资讯

玩家分享攻略“同城游贵阳捉鸡麻... 家人们!今天小编来为大家解答同城游贵阳捉鸡麻将透视挂怎么安装这个问题咨询软件客服徽9784099的挂...
最新引进“天蝎牛牛开挂器?”(... 有 亲,根据资深记者爆料天蝎牛牛是可以开挂的,确实有挂(咨询软件无需打开...
【今日要闻】“樱花炸/金/花开... 有 亲,根据资深记者爆料樱花炸/金/花是可以开挂的,确实有挂(咨询软件无...
【第一财经】“上海明星麻将开挂... 【第一财经】“上海明星麻将开挂器?”(透视曝光猫腻)您好,上海明星麻将这个游戏其实有挂的,确实是有挂...
最新引进“微友山西麻将到底是不... 网上科普关于“微友山西麻将有没有挂”话题很是火热,小编也是针对微友山西麻将作*弊开挂的方法以及开挂对...
新能源车高速公路电量耗尽,司乘... 澎湃新闻记者 覃明近日,广东省公安厅微信公众号“广东交警”发布一则案例,一辆新能源汽车的驾驶人和乘客...
我来教教您“福建众娱到底是不是... 网上科普关于“福建众娱有没有挂”话题很是火热,小编也是针对福建众娱作*弊开挂的方法以及开挂对应的知识...
美媒爆料:为监听中国,美印曾在... 【文/观察者网 柳白】“为窃听中国,一台装满钚的核发电机在世界最高山峰之一神秘失踪,这是美国至今仍不...
【第一资讯】“爱玩联盟怎么装挂... 有 亲,根据资深记者爆料爱玩联盟是可以开挂的,确实有挂(咨询软件无需打开...
【第一财经】“新圣游炸/金/花... 【第一财经】“新圣游炸/金/花可以开挂吗?”(透视曝光猫腻)您好,新圣游炸/金/花这个游戏其实有挂的...