溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

k8s基礎中如何通過Volume保持數(shù)據(jù)持久

發(fā)布時間:2021-12-16 11:04:32 來源:億速云 閱讀:152 作者:柒染 欄目:云計算

這篇文章將為大家詳細講解有關(guān)k8s基礎中如何通過Volume保持數(shù)據(jù)持久 ,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

     一個運行中的容器對文件系統(tǒng)的寫入都是發(fā)生在其分層文件系統(tǒng)的可寫層。一旦容器運行結(jié)束,所有寫入都會被丟棄。如果數(shù)據(jù)需要長期存儲,那就需要對容器數(shù)據(jù)做持久化支持。

   Kubernetes 和 Docker 類似,也是通過 Volume 的方式提供對存儲的支持。Volume 被定義在 Pod 上,可以被 Pod 里的多個容器掛載到相同或不同的路徑下。          Kubernetes 中 Volume 的 概念與Docker 中的 Volume 類似,但不完全相同。具體區(qū)別如下:

    Kubernetes 中的 Volume 與 Pod 的生命周期相同,但與容器的生命周期不相關(guān)。當容器終止或重啟時,Volume 中的數(shù)據(jù)也不會丟失。

當 Pod 被刪除時,Volume 才會被清理。并且數(shù)據(jù)是否丟失取決于 Volume 的具體類型,比如:emptyDir 類型的 Volume 數(shù)據(jù)會丟失,而 PV 類型的數(shù)據(jù)則不會丟失。

Kubernetes 目前支持多種 Volume 類型,大致如下:

emptyDir

nfs

hostPath

gitRepo

persistentVolumeClaim

projected

portworxVolume

等等

下面對常見的做一下基本介紹

emptryDir

    如果Pod配置了EmpyDir數(shù)據(jù)卷,在Pod的生命周期內(nèi)都會存在,當Pod被分配到 Node上的時候,會在Node上創(chuàng)建EmptyDir數(shù)據(jù)卷,并掛載到Pod的容器中。只要Pod 存在,EmpyDir數(shù)據(jù)卷都會存在(容器刪除不會導致EmpyDir數(shù)據(jù)卷丟失數(shù)據(jù)),但是如果Pod的生命周期終結(jié)(Pod被刪除),EmpyDir數(shù)據(jù)卷也會被刪除,并且永久丟失。

示例演示:

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保持數(shù)據(jù)持久

k8s基礎中如何通過Volume保持數(shù)據(jù)持久

k8s 集群會在 node 節(jié)點上  創(chuàng)建EmptyDir數(shù)據(jù)卷

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

k8s基礎中如何通過Volume保持數(shù)據(jù)持久

在k8s-node1 上添加文件 

k8s基礎中如何通過Volume保持數(shù)據(jù)持久、

進入pod 容器中查看

k8s基礎中如何通過Volume保持數(shù)據(jù)持久

刪除pod 

kubectl delete -f emptyDir2.yaml

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

進入原來的目錄,臨時目錄已經(jīng)被刪除

k8s基礎中如何通過Volume保持數(shù)據(jù)持久

hostPath

hostPath類型則是映射node文件系統(tǒng)中的文件或者目錄到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保持數(shù)據(jù)持久

k8s基礎中如何通過Volume保持數(shù)據(jù)持久

進入掛載的/test-data目錄中,創(chuàng)建個測試文件

k8s基礎中如何通過Volume保持數(shù)據(jù)持久

創(chuàng)建測試文件

k8s基礎中如何通過Volume保持數(shù)據(jù)持久

在pod  運行的節(jié)點上查看

k8s基礎中如何通過Volume保持數(shù)據(jù)持久

ps 在node 節(jié)點的目錄里創(chuàng)建,容器里面也會自動生成

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

查看 node 節(jié)點上的 文件還在

k8s基礎中如何通過Volume保持數(shù)據(jù)持久

關(guān)于k8s基礎中如何通過Volume保持數(shù)據(jù)持久 就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI