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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...