man
страницу по vstorage-config-filesПлатформа виртуализации Р-Платформа поддерживает создание распределенных сред виртуализации и хранилища в рамках двух разнесенных площадках в рамках расстояния синхронной репликации. Данная конфигурация так-же известна под названием “растянутый кластер”.
Распределенный кластер предъявляет следующие требования к сетевой инфраструктуре:
При создании территориально распределенной конфигурации на платформе виртуализации Р-Платформа суммарное количество узлов на двух площадках должно быть четным а также должна быть развернута дополнительная машина с сервисом метаданных хранилища называемая “свидетель” на третьей площадке. Свидетель может быть выполнен как в виде физического сервера так и в виде виртуальной машины.
Требования к виртуальной машине свидетеля:
Установка платформы виртуализации в формате метро-кластера практически не отличается от развертывания системы в рамках одной площадки. Дополнительно к базовым задачам по установке и настройки узлов виртуализации необходимо выполнить следующие процедуры.
shaman
;
Каждый компонент Р-Хранилище обладает адресом, который состоит из 5 идентификаторов: room.row.rack.host_ID.cs_ID
Первые три адреса пути room.row.rack
можно настроить в файлах конфигурации /etc/vstorage/location
на каждом физическом сервере 1). Последние два компонента host_ID.cs_ID
генерируются автоматически:
Для задания расположения сервера между двумя центрами обработки данных необходимо на каждом сервере создать конфигурационный файл, описывающий его расположение
room.row.rack
где:
room
- номер виртуального помещения в формате числа от 0 до 9. ;row
- номер ряда;rack
- номер стойки в ряду;Данные номера не обязательно должны совпадать с номерами реального расположения оборудования а используются для создания логических сущностей в рамках домена отказа.
Серверы, которые находятся в одном домене отказа должны иметь одинаковые значения файла location.
Например для создания распределенной конфигурации с пятью доменами отказа файл location
может принимать следующие значения:
0.0.1
- для первого домена отказа на первой площадке;0.0.2
- для второго домена отказа на первой площадке;0.0.3
- для третьего домена отказа на второй площадке;0.0.4
- для четвертого домена отказа на второй площадке;
Создание кластера должно производиться только после установки корректного значения в файле location
.
Рекомендуемое количество сервисов метаданных в одном кластере хранения равно пяти. Поэтому для конфигурации с четырьмя доменами отказа (по 2 на каждую площадку) необходимо назначить по одному сервису метаданных в каждом домене отказа. Пятый домен отказа и диск с ролью метаданных будет расположен на “свидетеле”.
Машина свидетеля должна иметь только диски двух следующих ролей или один диск совмещающий две эти роли:
После создания кластера хранения необходимо создать хранилище для среды виртуализации штатным способом.
Для конфигурации метро кластера необходимо задать уровень отказоустойчивости для создаваемых хранилищ равным rf=4. Данное требование обсуловено тем что в случае выхода из строя одной площадки система будет сохранять как минимум две копии каждого блока данных.
Во избежание возникновения ситуации когда все 4 копии блока могут оказаться на одной площадке необходимо указать домен отказа равный rack
. Так как объединение серверов в 4 домена отказа путем правки файла /etc/vstorage/location
проводилось именно на третьем уровне расположения - rack
. Для этого, после создания хранилища для среды виртуализации или iSCSI или S3 необходимо установить аттрибут распределения блоков коммандой:
vstorage -c %CLUSTER_NAME% set-attr -R /mnt/vstorage/vols/datastores/%DATASTORE_NAME% failure-domain=rack
, где:
Для хранилищ другого типа настройка производится аналогичным образом.
После создания кластера хранения необходимо добавить все вычислительные узлы в систему управления виртуализацией Р-Управление. Сервер “свидетеля” не добавляется, потому что запуск виртуальных машин на данном сервере производиться не должен.
Служба shaman
запускается на всех серверах которые предназначены для запуска и выполнения виртуальных машин. На свидетеле команда hastart
не выполняется и служба shaman
не должна запускаться на данном сервере во избежание распределения на данный сервер виртуальных машин в случае сбоя.
Необходимо настроить максимальное количество узлов при котором служба shaman
продолжает работать. При превышении указанного числа сбой считается критичным и автоматическое восстановление работоспособности виртуальных машин не производится.
Параметр задается на одном из узлов, который подключен к кластерной службе.
shaman set-config RELOCATION_SKIP_THRESHOLD=n
, где число узлов n
необходимо установить равным суммарному числу узлов площадки или больше на один.
man
страницу по vstorage-config-files