Функциональность модуля может измениться, но основные возможности сохранятся. Совместимость с будущими версиями обеспечивается, но может потребовать дополнительных действий по миграции.
Работоспособность модуля гарантируется только при соблюдении требований. Работоспособность модуля в других условиях возможна, но не гарантируется.
Модуль управляет реплицируемым блочным хранилищем на базе DRBD
. На текущий момент в качестве control-plane используется LINSTOR
. Модуль позволяет создавать Storage Pool
в LINSTOR
и StorageClass
в Kubernetes
через создание пользовательских ресурсов Kubernetes.
Для создания Storage Pool
потребуются настроенные на узлах кластера LVMVolumeGroup
. Настройка LVM
осуществляется модулем sds-node-configurator.
Внимание! Перед включением модуля
sds-replicated-volume
необходимо включить модульsds-node-configurator
.Внимание! Непосредственная конфигурация бэкенда
LINSTOR
пользователем запрещена.Внимание! Синхронизация данных при репликации томов происходит только в синхронном режиме, асинхронный режим не поддерживается.
После включения модуля sds-replicated-volume
в конфигурации Deckhouse ваш кластер будет автоматически настроен на использование бэкенда LINSTOR
. Останется только создать пулы хранения и StorageClass’ы.
Внимание! Создание
StorageClass
для CSI-драйвера replicated.csi.storage.deckhouse.io пользователем запрещено.
Поддерживаются два режима — LVM и LVMThin. Каждый из них имеет свои достоинства и недостатки, подробнее о различиях читайте в FAQ.
Быстрый старт
Все команды следует выполнять на машине, имеющей доступ к API Kubernetes с правами администратора.
Включение модулей
- Включить модуль sds-node-configurator
kubectl apply -f - <<EOF
apiVersion: deckhouse.io/v1alpha1
kind: ModuleConfig
metadata:
name: sds-node-configurator
spec:
enabled: true
version: 1
EOF
- Дождаться, когда модуль перейдет в состояние
Ready
. На этом этапе НЕ нужно проверять поды в namespaced8-sds-node-configurator
.
kubectl get module sds-node-configurator -w
- Включить модуль
sds-replicated-volume
. Возможные настройки модуля рекомендуем посмотреть в конфигурации. В примере ниже модуль запускается с настройками по умолчанию. Это приведет к тому, что на всех узлах кластера будет:- установлен модуль ядра
DRBD
; - зарегистрирован CSI драйвер;
- запущены служебные поды компонентов
sds-replicated-volume
.
- установлен модуль ядра
kubectl apply -f - <<EOF
apiVersion: deckhouse.io/v1alpha1
kind: ModuleConfig
metadata:
name: sds-replicated-volume
spec:
enabled: true
version: 1
EOF
- Дождаться, когда модуль перейдет в состояние
Ready
.
kubectl get module sds-replicated-volume -w
- Проверить, что в namespace
d8-sds-replicated-volume
иd8-sds-node-configurator
все поды в состоянииRunning
илиCompleted
и запущены на всех узлах, где планируется использовать ресурсыDRBD
.
kubectl -n d8-sds-replicated-volume get pod -owide -w
kubectl -n d8-sds-node-configurator get pod -o wide -w
Настройка хранилища на узлах
Необходимо на этих узлах создать группы томов LVM
с помощью пользовательских ресурсов LVMVolumeGroup
. В быстром старте будем создавать обычное Thick
хранилище. Подробнее про пользовательские ресурсы и примеры их использования можно прочитать в примерах использования.
Приступим к настройке хранилища:
- Получить все ресурсы BlockDevice, которые доступны в вашем кластере:
kubectl get bd
NAME NODE CONSUMABLE SIZE PATH
dev-0a29d20f9640f3098934bca7325f3080d9b6ef74 worker-0 true 30Gi /dev/vdd
dev-457ab28d75c6e9c0dfd50febaac785c838f9bf97 worker-0 false 20Gi /dev/vde
dev-49ff548dfacba65d951d2886c6ffc25d345bb548 worker-1 true 35Gi /dev/vde
dev-75d455a9c59858cf2b571d196ffd9883f1349d2e worker-2 true 35Gi /dev/vdd
dev-ecf886f85638ee6af563e5f848d2878abae1dcfd worker-0 true 5Gi /dev/vdb
- Создать ресурс LVMVolumeGroup для узла
worker-0
:
kubectl apply -f - <<EOF
apiVersion: storage.deckhouse.io/v1alpha1
kind: LvmVolumeGroup
metadata:
name: "vg-1-on-worker-0" # Имя может быть любым подходящим для имен ресурсов в Kubernetes. Именно это имя ресурса LvmVolumeGroup будет в дальнейшем использоваться для создания ReplicatedStoragePool
spec:
type: Local
blockDeviceNames: # указываем имена ресурсов BlockDevice, которые расположены на нужной нам узле и CONSUMABLE которых выставлен в true. Обратите внимание, что имя узлы мы ннигде не указываем. Имя узлы берется из ресурсов BlockDevice
- dev-0a29d20f9640f3098934bca7325f3080d9b6ef74
- dev-ecf886f85638ee6af563e5f848d2878abae1dcfd
actualVGNameOnTheNode: "vg-1" # имя LVM VG, которая будет создана на узле из указанных выше блочных устройств
EOF
- Дождаться, когда созданный ресурс
LVMVolumeGroup
перейдет в состояниеOperational
:
kubectl get lvg vg-1-on-worker-0 -w
-
Если ресурс перешел в состояние
Operational
, то это значит, что на узлеworker-0
из блочных устройств/dev/vdd
и/dev/vdb
была создана LVM VG с именемvg-1
. -
Далее создать ресурс LVMVolumeGroup для узла
worker-1
:
kubectl apply -f - <<EOF
apiVersion: storage.deckhouse.io/v1alpha1
kind: LvmVolumeGroup
metadata:
name: "vg-1-on-worker-1"
spec:
type: Local
blockDeviceNames:
- dev-49ff548dfacba65d951d2886c6ffc25d345bb548
actualVGNameOnTheNode: "vg-1"
EOF
- Дождаться, когда созданный ресурс
LVMVolumeGroup
перейдет в состояниеOperational
:
kubectl get lvg vg-1-on-worker-1 -w
-
Если ресурс перешел в состояние
Operational
, то это значит, что на узлеworker-1
из блочного устройства/dev/vde
была создана LVM VG с именемvg-1
. -
Далее создать ресурс LVMVolumeGroup для узла
worker-2
:
kubectl apply -f - <<EOF
apiVersion: storage.deckhouse.io/v1alpha1
kind: LvmVolumeGroup
metadata:
name: "vg-1-on-worker-2"
spec:
type: Local
blockDeviceNames:
- dev-75d455a9c59858cf2b571d196ffd9883f1349d2e
actualVGNameOnTheNode: "vg-1"
EOF
- Дождаться, когда созданный ресурс
LVMVolumeGroup
перейдет в состояниеOperational
:
kubectl get lvg vg-1-on-worker-2 -w
-
Если ресурс перешел в состояние
Operational
, то это значит, что на узлеworker-2
из блочного устройства/dev/vdd
была создана LVM VG с именемvg-1
. -
Теперь, когда у нас на узлах созданы нужные LVM VG, мы можем создать из них ReplicatedStoragePool:
kubectl apply -f -<<EOF
apiVersion: storage.deckhouse.io/v1alpha1
kind: ReplicatedStoragePool
metadata:
name: data
spec:
type: LVM
lvmVolumeGroups: # Здесь указываем имена ресурсов LvmVolumeGroup, которые мы создавали ранее
- name: vg-1-on-worker-0
- name: vg-1-on-worker-1
- name: vg-1-on-worker-2
EOF
- Дождаться, когда созданный ресурс
ReplicatedStoragePool
перейдет в состояниеCompleted
:
kubectl get rsp data -w
- Проверить, что в LINSTOR создался Storage Pool
data
на узлахworker-0
,worker-1
иworker-2
:
alias linstor='kubectl -n d8-sds-replicated-volume exec -ti deploy/linstor-controller -- linstor'
linstor sp l
╭─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╮
┊ StoragePool ┊ Node ┊ Driver ┊ PoolName ┊ FreeCapacity ┊ TotalCapacity ┊ CanSnapshots ┊ State ┊ SharedName ┊
╞═════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════╡
┊ DfltDisklessStorPool ┊ worker-0 ┊ DISKLESS ┊ ┊ ┊ ┊ False ┊ Ok ┊ worker-0;DfltDisklessStorPool ┊
┊ DfltDisklessStorPool ┊ worker-1 ┊ DISKLESS ┊ ┊ ┊ ┊ False ┊ Ok ┊ worker-1;DfltDisklessStorPool ┊
┊ DfltDisklessStorPool ┊ worker-2 ┊ DISKLESS ┊ ┊ ┊ ┊ False ┊ Ok ┊ worker-2;DfltDisklessStorPool ┊
┊ data ┊ worker-0 ┊ LVM ┊ vg-1 ┊ 35.00 GiB ┊ 35.00 GiB ┊ False ┊ Ok ┊ worker-0;data ┊
┊ data ┊ worker-1 ┊ LVM ┊ vg-1 ┊ 35.00 GiB ┊ 35.00 GiB ┊ False ┊ Ok ┊ worker-1;data ┊
┊ data ┊ worker-2 ┊ LVM ┊ vg-1 ┊ 35.00 GiB ┊ 35.00 GiB ┊ False ┊ Ok ┊ worker-2;data ┊
╰─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯
- Создать ресурс ReplicatedStorageClass для кластера, в котором нет зон (работа зональных ReplicatedStorageClass подробнее описана в сценариях использования):
kubectl apply -f -<<EOF
apiVersion: storage.deckhouse.io/v1alpha1
kind: ReplicatedStorageClass
metadata:
name: replicated-storage-class
spec:
storagePool: data # Указываем имя ReplicatedStoragePool, созданного ранее
reclaimPolicy: Delete
topology: Ignored # - если указываем такую топологию, то в кластере не должно быть зон (узлов с метками topology.kubernetes.io/zone).
EOF
- Дождаться, когда созданный ресурс
ReplicatedStorageClass
перейдет в состояниеCreated
:
kubectl get rsc replicated-storage-class -w
- Проверить, что соответствующий
StorageClass
создался:
kubectl get sc replicated-storage-class
- Если
StorageClass
с именемreplicated-storage-class
появился, значит настройка модуляsds-replicated-volume
завершена. Теперь пользователи могут создавать PV, указываяStorageClass
с именемreplicated-storage-class
. При указанных выше настройках будет создаваться том с 3мя репликами на разных узлах.
Системные требования и рекомендации
Требования
- Использование стоковых ядер, поставляемых вместе с поддерживаемыми дистрибутивами;
- Использование сети 10Gbps.
- Не использовать другой SDS (Software defined storage) для предоставления дисков нашему SDS