Yandex Cloud
Поиск
Связаться с намиПодключиться
  • Документация
  • Блог
  • Все сервисы
  • Статус работы сервисов
    • Популярные
    • Инфраструктура и сеть
    • Платформа данных
    • Контейнеры
    • Инструменты разработчика
    • Бессерверные вычисления
    • Безопасность
    • Мониторинг и управление ресурсами
    • Машинное обучение
    • Бизнес-инструменты
  • Все решения
    • По отраслям
    • По типу задач
    • Экономика платформы
    • Безопасность
    • Техническая поддержка
    • Каталог партнёров
    • Обучение и сертификация
    • Облако для стартапов
    • Облако для крупного бизнеса
    • Центр технологий для общества
    • Облако для интеграторов
    • Поддержка IT-бизнеса
    • Облако для фрилансеров
    • Обучение и сертификация
    • Блог
    • Документация
    • Контент-программа
    • Мероприятия и вебинары
    • Контакты, чаты и сообщества
    • Идеи
    • Истории успеха
    • Тарифы Yandex Cloud
    • Промоакции и free tier
    • Правила тарификации
  • Документация
  • Блог
Проект Яндекса
© 2025 ООО «Яндекс.Облако»
Yandex Managed Service for Kubernetes
  • Сопоставление с другими сервисами Yandex Cloud
  • Начало работы
    • Все инструкции
    • Подключение к узлу по SSH
    • Подключение к узлу через OS Login
    • Обновление Kubernetes
    • Настройка автомасштабирования
      • Динамическая подготовка тома
      • Статическая подготовка тома
      • Управление классами хранилищ
      • Увеличение размера тома для подов
      • Увеличение размера тома для контроллера StatefulSet
      • Подключение тома в блочном режиме
      • Интеграция с Object Storage
    • Подключение внешних узлов к кластеру
  • Управление доступом
  • Правила тарификации
  • Справочник Terraform
  • Метрики Monitoring
  • Аудитные логи Audit Trails
  • История изменений
  • Обучающие курсы

В этой статье:

  • Создайте класс хранилищ
  • Формат спецификации для создания класса хранилищ
  • Измените класс хранилищ по умолчанию
  1. Пошаговые инструкции
  2. Работа с постоянными томами
  3. Управление классами хранилищ

Управление классами хранилищ

Статья создана
Yandex Cloud
Обновлена 12 марта 2025 г.
  • Создайте класс хранилищ
    • Формат спецификации для создания класса хранилищ
  • Измените класс хранилищ по умолчанию

Класс хранилищ (StorageClass) предоставляет администраторам возможность разделить хранилища, которые они предлагают, на классы с определенными параметрами. Классы отличаются типом создаваемого диска и правилами тарификации.

Внимание

Стоимость использования хранилища зависит от типа его диска. Ознакомьтесь с ценами на диски Yandex Compute Cloud перед созданием хранилища.

В Managed Service for Kubernetes доступны следующие классы хранилищ, которые отличаются типом создаваемого диска:

  • yc-network-hdd (используется по умолчанию) — хранилище на сетевых HDD-дисках (network-hdd).
  • yc-network-ssd — хранилище на сетевых SSD-дисках (network-ssd).
  • yc-network-ssd-nonreplicated — хранилище на нереплицируемых SSD-дисках с повышенной производительностью (network-ssd-nonreplicated).
  • yc-network-ssd-io-m3 — хранилище на сетевых SSD-дисках с повышенной производительностью (network-ssd-io-m3).

Внимание

Нереплицируемые диски не имеют резервирования. При выходе диска из строя данные будут утеряны безвозвратно. Подробнее см. в разделе Нереплицируемые диски и сверхбыстрые сетевые хранилища с тремя репликами (SSD).

Все хранилища создаются с параметрами:

  • Volume Binding Mode — WaitForFirstConsumer.
  • Reclaim Policy — Delete.

Данные классы допускают использование объектов PersistentVolumeClaim и PersistentVolume только в режиме доступа ReadWriteOnce.

Вы можете создать свой класс хранилищ, а также изменить класс хранилищ по умолчанию.

Перед началом работы установите kubectl и настройте его на работу с созданным кластером Managed Service for Kubernetes.

Примечание

Класс yc-network-nvme является устаревшим. Вместо него используйте класс yc-network-ssd.

Создайте класс хранилищСоздайте класс хранилищ

  1. Сохраните спецификацию для создания класса хранилищ в YAML-файл my-sc-hdd.yaml:

    Подробнее про формат спецификации для создания класса хранилищ.

    kind: StorageClass
    apiVersion: storage.k8s.io/v1
    metadata:
      name: my-sc-hdd
    provisioner: disk-csi-driver.mks.ycloud.io
    volumeBindingMode: WaitForFirstConsumer
    parameters:
      type: network-hdd
      csi.storage.k8s.io/fstype: ext4
    allowVolumeExpansion: false
    reclaimPolicy: Retain
    
  2. Выполните команду:

    kubectl create -f my-sc-hdd.yaml
    

    Результат:

    storageclass.storage.k8s.io/my-sc-hdd created
    
  3. Проверьте, что класс хранилищ создался:

    kubectl get storageclass
    

    Результат:

    NAME                      PROVISIONER                    AGE
    my-sc-hdd                 disk-csi-driver.mks.ycloud.io  76s
    yc-network-hdd (default)  disk-csi-driver.mks.ycloud.io  16m
    yc-network-ssd            disk-csi-driver.mks.ycloud.io  16m
    

Формат спецификации для создания класса хранилищФормат спецификации для создания класса хранилищ

Каждый объект StorageClass содержит параметры parameters, allowVolumeExpansion и reclaimPolicy, которые используются для динамического выделения объекта PersistentVolume.

Структура YAML-файла:

kind: StorageClass
apiVersion: storage.k8s.io/v1
metadata:
  name: <имя_класса_хранилищ> # Используется для обращения к классу хранилищ.
provisioner: <имя_поставщика>
volumeBindingMode: WaitForFirstConsumer
parameters: # Параметры класса хранилищ.
  type: <тип_диска>
  csi.storage.k8s.io/fstype: <тип_файловой_системы>
allowVolumeExpansion: <включение_механизма_увеличения_размера_тома>
reclaimPolicy: <политика_переиспользования>

Допустимые значения параметров:

  • parameters:
    • type — network-hdd, network-ssd, network-ssd-nonreplicated или network-ssd-io-m3.
    • csi.storage.k8s.io/fstype — ext2, ext3 или ext4.
  • reclaimPolicy — Retain или Delete.
  • allowVolumeExpansion — true или false.

Измените класс хранилищ по умолчаниюИзмените класс хранилищ по умолчанию

  1. Посмотрите, какой класс хранилищ установлен по умолчанию. Рядом с его названием в скобках будет указано default.

    kubectl get storageclass
    

    Результат:

    NAME                      PROVISIONER                    AGE
    my-sc-hdd                 disk-csi-driver.mks.ycloud.io  76s
    yc-network-hdd (default)  disk-csi-driver.mks.ycloud.io  16m
    yc-network-ssd            disk-csi-driver.mks.ycloud.io  16m
    
  2. Измените параметр storageclass.kubernetes.io/is-default-class класса хранилищ по умолчанию на false, чтобы он перестал быть классом по умолчанию:

    kubectl patch storageclass yc-network-hdd \
      -p '{"metadata": {"annotations":{"storageclass.kubernetes.io/is-default-class":"false"}}}'
    
  3. Проверьте, что yc-network-hdd больше не является классом хранилищ по умолчанию:

    kubectl get storageclass
    

    Результат:

    NAME            PROVISIONER                    AGE
    my-sc-hdd       disk-csi-driver.mks.ycloud.io  2m36s
    yc-network-hdd  disk-csi-driver.mks.ycloud.io  17m
    yc-network-ssd  disk-csi-driver.mks.ycloud.io  17m
    
  4. Укажите новый класс хранилищ по умолчанию, например my-sc-hdd:

    kubectl patch storageclass my-sc-hdd \
      -p '{"metadata": {"annotations":{"storageclass.kubernetes.io/is-default-class":"true"}}}'
    
  5. Проверьте, что my-sc-hdd стал классом хранилищ по умолчанию:

    kubectl get storageclass
    

    Результат:

    NAME                 PROVISIONER                    AGE
    my-sc-hdd (default)  disk-csi-driver.mks.ycloud.io  4m21s
    yc-network-hdd       disk-csi-driver.mks.ycloud.io  19m
    yc-network-ssd       disk-csi-driver.mks.ycloud.io  19m
    

Была ли статья полезна?

Предыдущая
Статическая подготовка тома
Следующая
Увеличение размера тома для подов
Проект Яндекса
© 2025 ООО «Яндекс.Облако»