k8s基礎中如何通過Volume保持數據持久-創(chuàng)新互聯

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

我們提供的服務有:成都做網站、網站設計、外貿營銷網站建設、微信公眾號開發(fā)、網站優(yōu)化、網站認證、維西ssl等。為近1000家企事業(yè)單位解決了網站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的維西網站制作公司

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

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

  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上創(chuàng)建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 節(jié)點上 創(chuàng)建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目錄中,創(chuàng)建個測試文件

k8s基礎中如何通過Volume保持數據持久

創(chuàng)建測試文件

k8s基礎中如何通過Volume保持數據持久

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

k8s基礎中如何通過Volume保持數據持久

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

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

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

k8s基礎中如何通過Volume保持數據持久

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

另外有需要云服務器可以了解下創(chuàng)新互聯cdcxhl.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

分享標題:k8s基礎中如何通過Volume保持數據持久-創(chuàng)新互聯
瀏覽地址:http://bm7419.com/article0/didpoo.html

成都網站建設公司_創(chuàng)新互聯,為您提供定制開發(fā)、品牌網站設計面包屑導航、手機網站建設域名注冊、做網站

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

網站優(yōu)化排名