044.集群存儲-StorageClass

来源:https://www.cnblogs.com/itzgr/archive/2020/04/03/12625522.html
-Advertisement-
Play Games

一 StoragClass 1.1 StorageClass概述 StorageClass作為對存儲資源的抽象定義,對用戶設置的PVC申請屏蔽後端存儲的細節,一方面減少了用戶對於存儲資源細節的關註,另一方面減輕了管理員手工管理PV的工作,由系統自動完成PV的創建和綁定,實現了動態的資源供應。 基於S ...


一 StoragClass

1.1 StorageClass概述

StorageClass作為對存儲資源的抽象定義,對用戶設置的PVC申請屏蔽後端存儲的細節,一方面減少了用戶對於存儲資源細節的關註,另一方面減輕了管理員手工管理PV的工作,由系統自動完成PV的創建和綁定,實現了動態的資源供應。 基於StorageClass的動態資源供應模式將逐步成為雲平臺的標準存儲配置模式。StorageClass的定義主要包括名稱、後端存儲的提供者(provisioner)和後端存儲的相關參數配置。 StorageClass一旦被創建出來,則將無法修改。如需更改,則只能刪除原StorageClass的定義重建。 示例1:定義一個名為standard的StorageClass,提供者為aws-ebs,其參數設置了一個type,值為gp2。 [root@k8smaster01 study]# vi awsclass01.yaml
  1 kind: StorageClass
  2 apiVersion: storage.k8s.io/v1
  3 metadata:
  4   name: standard
  5 provisioner: kubernetes.io/aws-bs
  6 parameters:
  7   type: gp2
  8 

1.2 StorageClass配置參數

  • 提供者(Provisioner)
描述存儲資源的提供者,也可以看作後端存儲驅動。目前Kubernetes支持的Provisioner都以“kubernetes.io/”為開頭,用戶也可以使用自定義的後端存儲提供者。
  • 參數(Parameters)
後端存儲資源提供者的參數設置,不同的Provisioner包括不同的參數設置。某些參數可以不顯示設定,Provisioner將使用其預設值。

1.3 常見Provisioner

  • AWSEBS存儲捲
  1 kind: StorageClass
  2 apiVersion: storage.k8s.io/v1
  3 metadata:
  4   name: slow
  5 provisioner: kubernetes.io/aws-ebs
  6 parameters:
  7   type: io1
  8   zone: us-east-1d
  9   iopsPerGB: "10"
 10 
參數說明如下(詳細說明請參考AWSEBS文檔):
    • type:可選項為io1,gp2,sc1,st1,預設值為gp2。
    • zone:AWSzone的名稱。
    • iopsPerGB:僅用於io1類型的Volume,意為每秒每GiB的I/O操作數量。
    • encrypted:是否加密。
    • kmsKeyId:加密時的Amazon Resource Name。
  • GCEPD存儲捲
  1 kind: StorageClass
  2 apiVersion: storage.k8s.io/v1
  3 metadata:
  4   name: slow
  5 provisioner: kubernetes.io/gce-pd
  6 parameters:
  7   type: pd-standard
  8   zone: us-centrall-a
  9 
參數說明如下(詳細說明請參考GCE文檔):
    • type:可選項為pd-standard、pd-ssd,預設值為pd-standard。
    • zone:GCEzone名稱。
  • GlusterFS存儲捲
  1 apiVersion: storage.k8s.io/v1
  2 kind: StorageClass
  3 metadata:
  4   name: slow
  5 provisioner: kubernetes.io/glusterfes
  6 parameters:
  7   resturl: "http://127.0.0.1:8081"
  8   clusterid: "xxxxxxxxxxxx"
  9   restauthenabled: "true"
 10   restuser: "admin"
 11   secretNamespace: "default"
 12   secretName: "heketi-secret"
 13   gidMin: "40000"
 14   gidMax: "50000"
 15   volumetype: "replicate:3"
 16 
參數說明如下(詳細說明請參考GlusterFS和Heketi的文檔):
    • resturl:GlusterREST服務(Heketi)的URL地址,用於自動完成GlusterFSvolume的設置。
    • restauthenabled:是否對GlusterREST服務啟用安全機制。
    • restuser:訪問GlusterREST服務的用戶名。
    • secretNamespace和secretName:保存訪問GlusterREST服務密碼的Secret資源對象名。
    • clusterid:GlusterFS的ClusterID。
    • gidMin和gidMax:StorageClass的GID範圍,用於動態資源供應時為PV設置的GID。
    • volumetype:設置GlusterFS的內部Volume類型,例如replicate:3(Replicate類型,3份副本);disperse:4:2(Disperse類型,數據4份,冗餘兩份;“none”(Distribute類型)。
  • OpenStackCinder存儲捲
  1 kind: StorageClass
  2 apiVersion: storage.k8s.io/v1
  3 metadata:
  4   name: gold
  5 provisioner: kubernetes.io/cinder
  6 parameters:
  7   type: fast
  8   availability: nova
  9 
參數說明如下。
    • type:Cinder的VolumeType,預設值為空。
    • availability:AvailabilityZone,預設值為空。

1.4 設置預設StorageClass

要在系統中設置一個預設的StorageClass,則首先需要啟用名為DefaultStorageClass的admission controller,即在kube-apiserver的命令行參數--admission-control中增加: --admission-control-...,DefaultStorageClass [root@k8smaster01 study]# vi /etc/kubernetes/manifests/kube-apiserver.yaml
  1 ……
  2     - --enable-admission-plugins=NodeRestriction,DefaultStorageClass
  3 ……
  4 
[root@k8smaster01 study]# systemctl restart docker kubelet 然後,在StorageClass的定義中設置一個annotation: [root@k8smaster01 study]# vi defaultclass01.yaml
  1 kind: StorageClass
  2 apiVersion: storage.k8s.io/v1
  3 metadata:
  4   name: gold
  5   annotations:
  6     storageclass.beta.kubernetes.io/is-default-class="true"
  7 provisioner: kubernetes.io/gce-pd
  8 parameters:
  9   type: pd-ssd
 10 
通過kubectl create命令創建成功後,查看StorageClass列表,可以看到名為gold的StorageClass被標記為default:

二 動態管理存儲捲

2.1 glusterfs

見《附009.Kubernetes永久存儲之GlusterFS獨立部署》和《附010.Kubernetes永久存儲之GlusterFS超融合部署》。
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 基於C#的ASP.NET @2020.4.2 用戶系統+管理員系統——錯誤篇1_編譯錯誤 【背景】 1、使用軟體: Microsoft visual studio 2010, SQL Server 2008 2、運行對象: 基於C#編寫的ASP.NET系統中的管理員系統web窗體【manage.as ...
  • 一、屬性觸發器 要改變的屬性值不能再控制項裡面設置初始值,否則不能觸發,如下例的Width 二、數據觸發器 相比對屬性觸發器而言,他可以綁定其他控制項的屬性或者ViewModel裡面的屬性 三、事件觸發器 1. 只能觸發故事板(不知道是否正確) 2. 分為控制項觸發器和樣式觸發器(這兩個名字自己取的,也不 ...
  • 生成隨機數,第一反應肯定是 類,然而, 生成的隨機數被稱為偽隨機數,因為用 生成隨機數時,需要用到一個“種子”,而 使用相同的種子,一定會產生相同序列的數字 。 如果在創建 時沒有提供種子,那麼就將用當前系統時間來生成種子。 由於系統時鐘只有有限的粒度,因此兩個創建時間非常相近(一般在 10 毫秒之 ...
  • 在使用Git管理Visual Studio的工程時,經常會碰到這種情況: 整個工程文件夾有100多M,而源代碼只有100多K。如果全部添加進Git,那每次編譯時產生100M垃圾,10次Git提交就會使Git工程的大小突破1G! 怎麼解決這種問題呢?很簡單,創建一個名為.gitignore的文本文件在 ...
  • Vim是一款運行在命令行里的文字編輯器,它是Linux人員的標配。在Windows環境下也可以有特別的用處,比如創建沒有文件名的文件(.gitignore)。 Vim的功能十分強大,以至於有一些人對它十分恐懼。今天我們來簡單地使用vim編輯一個文本文檔,看看如何進行基本的編輯操作。 首先你要確保你有 ...
  • VCL(varnish configuration lanuage)是“域”專有類型的配置語言,主要用於編寫緩存策略的,VCL有多個狀態引擎,狀態之間存在相關性,但狀態引擎彼此互相隔離;每個狀態引擎可使用return(X)指明至那個下一級引擎;每個狀態引擎對應於vcl文件中的一個配置端,即為sub... ...
  • 有時候,我們在使用 Linux 系統時,會出現下麵這樣的情景: 1. 一個命令或程式需要很長時間才能運行完畢,在這過程中,系統可能會假死,我們做任何操作都沒用,只好重啟系統; 2. 我們僅僅想讓命令或程式運行指定的時間,到了時間點就讓命令/程式中止; 3. Log 刷新很快,但我們只需要 10 秒鐘 ...
  • 一 CSI存儲機制 1.1 CSI簡介 Kubernetes從1.9版本開始引入容器存儲介面Container Storage Interface(CSI)機制,用於在Kubernetes和外部存儲系統之間建立一套標準的存儲管理介面,通過該介面為容器提供存儲服務。 1.2 CSI的設計背景 Kube ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...