發現、初談 StatefulSet
StatefulSet 特色:
過去談過 Deployment、ReplicaSet 所創建的 Pod 皆屬於 stateless 的情況。 但如要建立 stateful 特性的服務資源物件,可以透過 StatefulSet 完成建立。 對於想要實現下列服務目的者,使用 StatefulSet 是最恰當的~
穩定的唯一性網路標誌 Stable, unique network identifiers.
穩定的持久化儲存服務 Stable, persistent storage.
有序性的實現部署和擴充 Ordered, graceful deployment and scaling.
有序性的滾動更新 Ordered, automated rolling updates.
以上,除了服務 stateful & stateless 重要差異之外, 特別凸顯了 Stable 穩定、Ordered 有序的字眼,這就是與 Deployment 之間最大差別。
StatefulSet 條件限制:
K8s 版本必須是 1.9 版本之後
用於 Pod 的儲存必須由 PersistentVolume Provisioner 根据 storage class 進行配置或者管理員事先配置。
刪除或者擴容 StatefulSet 時不會刪除相關的儲存區;這是為了確保資料的安全。
StatefulSets 目前需要 Headless Service 來負責 Pod 網路定義。
StatefulSets 刪除時,並不保證 pod 完美的終止服務。
StatefulSets 中實現 pod 的有序性和正常終止,可以在刪除之前將 StatefulSet 縮小到 0。
展示 StatefulSet 配置
配置中分三項說明:
Headless Service:名稱 nginx,用於控制網路
StatefulSet:名稱 web,有指定三個副本 replicas
volumeClaimTemplates:透過 PersistentVolumes provisioned 提供穩定的儲存服務
注意 Pod Selector:
在 StatefulSet yaml 定義中,必須有 .spec.template.metadata.labels;
在 K8s 1.8 版本之前,Pod Selector 是可以被省略的;
在 K8s 1.9 版本之後,如沒有設定正確的 Pod Selector 是會造成建立 StatefulSet 失敗。
Last updated