k8s 基礎學習之 數據持久 Volume

     一個運行中的容器對文件系統的寫入都是發生在其分層文件系統的可寫層。一旦容器運行結束,全部寫入都會被丟棄。若是數據須要長期存儲,那就須要對容器數據作持久化支持。node

   Kubernetes 和 Docker 相似,也是經過 Volume 的方式提供對存儲的支持。Volume 被定義在 Pod 上,能夠被 Pod 裏的多個容器掛載到相同或不一樣的路徑下。          Kubernetes 中 Volume 的 概念與Docker 中的 Volume 相似,但不徹底相同。具體區別以下:python

    Kubernetes 中的 Volume 與 Pod 的生命週期相同,但與容器的生命週期不相關。當容器終止或重啓時,Volume 中的數據也不會丟失。
git

當 Pod 被刪除時,Volume 纔會被清理。而且數據是否丟失取決於 Volume 的具體類型,好比:emptyDir 類型的 Volume 數據會丟失,而 PV 類型的數據則不會丟失。api


Kubernetes 目前支持多種 Volume 類型,大體以下:ide


emptyDir測試

nfsspa

hostPath3d

gitRepoorm


persistentVolumeClaimblog

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

image.png

image.png

k8s 集羣會在 node 節點上  建立EmptyDir數據卷

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

image.png

在k8s-node1 上添加文件 

image.png

進入pod 容器中查看

image.png

刪除pod 

kubectl delete -f emptyDir2.yaml

k8s-node1 臨時目錄就會被刪除

進入原來的目錄,臨時目錄已經被刪除

image.png

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

image.png


image.png

進入掛載的/test-data目錄中,建立個測試文件

image.png

建立測試文件


image.png

在pod  運行的節點上查看

image.png

ps 在node 節點的目錄裏建立,容器裏面也會自動生成


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


查看 node 節點上的 文件還在


image.png

相關文章
相關標籤/搜索