Изменение версии и редакции Elasticsearch
Важно
Сервис Yandex Managed Service for Elasticsearch недоступен с 11 апреля 2024 года.
Вы можете создать кластер OpenSearch в Yandex Cloud в качестве альтернативы Elasticsearch.
В кластере Managed Service for Elasticsearch вы можете обновить версию и изменить редакцию Elasticsearch.
Об обновлениях в рамках одной версии и обслуживании хостов см. в разделе Техническое обслуживание.
Обновление версии Elasticsearch
Вы можете обновить кластер Managed Service for Elasticsearch до более новой версии Elasticsearch.
Узнать доступные версии Elasticsearch
- В консоли управления
перейдите на страницу каталога и выберите сервис Managed Service for Elasticsearch. - Выберите кластер и нажмите кнопку
Редактировать. - Откройте список в поле Версия.
Перед обновлением версии
Убедитесь, что это не нарушит работу ваших приложений:
- Посмотрите в истории изменений
Elasticsearch, как обновления могут повлиять на работу ваших приложений. - Попробуйте обновить версию на тестовом кластере. Его можно развернуть из резервной копии основного кластера.
- Создайте резервную копию основного кластера непосредственно перед обновлением версии.
Обновить версию Elasticsearch
- В консоли управления
перейдите на страницу каталога и выберите сервис Managed Service for Elasticsearch. - Выберите кластер и нажмите кнопку
Редактировать. - В поле Версия выберите нужную версию Elasticsearch.
- Нажмите кнопку Сохранить.
Если у вас еще нет интерфейса командной строки Yandex Cloud, установите и инициализируйте его.
По умолчанию используется каталог, указанный в профиле CLI. Вы можете указать другой каталог с помощью параметра --folder-name
или --folder-id
.
-
Получите список ваших кластеров Elasticsearch:
yc managed-elasticsearch cluster list
-
Получите информацию о нужном кластере и проверьте версию в свойстве
config.version
:yc managed-elasticsearch cluster get <имя_или_идентификатор_кластера>
-
Обновите версию:
yc managed-elasticsearch cluster update <имя_или_идентификатор_кластера> --version <версия_Elasticsearch>
-
Откройте актуальный конфигурационный файл Terraform с планом инфраструктуры.
О том, как создать такой файл, см. в разделе Создание кластера.
Полный список доступных для изменения полей конфигурации кластера Managed Service for Elasticsearch см. в документации провайдера Terraform
. -
Добавьте к описанию кластера Managed Service for Elasticsearch поле
config.version
или измените его значение, если оно уже существует:resource "yandex_mdb_elasticsearch_cluster" "<имя_кластера>" { ... config { version = "<версия_Elasticsearch>" } }
-
Проверьте корректность настроек.
-
В командной строке перейдите в каталог, в котором расположены актуальные конфигурационные файлы Terraform с планом инфраструктуры.
-
Выполните команду:
terraform validate
Если в файлах конфигурации есть ошибки, Terraform на них укажет.
-
-
Подтвердите изменение ресурсов.
-
Выполните команду для просмотра планируемых изменений:
terraform plan
Если конфигурации ресурсов описаны верно, в терминале отобразится список изменяемых ресурсов и их параметров. Это проверочный этап: ресурсы не будут изменены.
-
Если вас устраивают планируемые изменения, внесите их:
-
Выполните команду:
terraform apply
-
Подтвердите изменение ресурсов.
-
Дождитесь завершения операции.
-
Ограничения по времени
Провайдер Terraform ограничивает время на выполнение операций с кластером Managed Service for Elasticsearch:
- создание, в т. ч. путем восстановления из резервной копии, — 30 минут;
- изменение — 60 минут;
- удаление — 15 минут.
Операции, длящиеся дольше указанного времени, прерываются.
Как изменить эти ограничения?
Добавьте к описанию кластера блок
timeouts
, например:resource "yandex_mdb_elasticsearch_cluster" "<имя_кластера>" { ... timeouts { create = "1h30m" # Полтора часа update = "2h" # 2 часа delete = "30m" # 30 минут } }
-
Чтобы обновить версию, воспользуйтесь методом REST API update для ресурса Cluster или вызовом gRPC API ClusterService/Update и передайте в запросе:
-
Идентификатор кластера в параметре
clusterId
.Идентификатор кластера можно получить со списком кластеров в каталоге.
-
Новую версию Elasticsearch в параметре
configSpec.version
. -
Список изменяемых полей конфигурации кластера в параметре
updateMask
(в данном случае —configSpec.version
).
Важно
Метод API переопределит все параметры изменяемого объекта, которые не были явно переданы в запросе, на значения по умолчанию. Чтобы избежать этого, перечислите настройки, которые вы хотите изменить, в параметре updateMask
(одной строкой через запятую).
Изменить редакцию Elasticsearch
Примечание
С 13 июня 2022 года прекращена поддержка редакции Gold
в кластерах Managed Service for Elasticsearch. Перейти на нее с редакций Basic
или Platinum
невозможно. 6 июля 2022 года редакция всех кластеров Gold
была автоматически повышена до Platinum
.
Вы можете изменить используемую кластером редакцию Elasticsearch. Прежде чем понижать используемую редакцию, убедитесь, что сокращение функциональных возможностей не нарушит работу ваших приложений.
- В консоли управления
перейдите на страницу каталога и выберите сервис Managed Service for Elasticsearch. - Выберите кластер и нажмите кнопку
Редактировать. - В поле Редакция выберите нужную редакцию Elasticsearch:
Basic
илиPlatinum
. - Нажмите кнопку Сохранить.
Если у вас еще нет интерфейса командной строки Yandex Cloud, установите и инициализируйте его.
По умолчанию используется каталог, указанный в профиле CLI. Вы можете указать другой каталог с помощью параметра --folder-name
или --folder-id
.
-
Получите список ваших кластеров Elasticsearch:
yc managed-elasticsearch cluster list
-
Получите информацию о нужном кластере и проверьте редакцию в свойстве
config.edition
:yc managed-elasticsearch cluster get <имя_или_идентификатор_кластера>
-
Измените редакцию:
yc managed-elasticsearch cluster update <имя_или_идентификатор_кластера> \ --edition <редакция_Elasticsearch>
Где
--edition
— редакция Elasticsearch:basic
илиplatinum
.
-
Откройте актуальный конфигурационный файл Terraform с планом инфраструктуры.
О том, как создать такой файл, см. в разделе Создание кластера.
-
Добавьте к описанию кластера Managed Service for Elasticsearch поле
config.edition
или измените его значение, если поле уже существует:resource "yandex_mdb_elasticsearch_cluster" "<имя_кластера>" { ... config { edition = "<редакция_Elasticsearch>" ... } ... }
Где
edition
— редакция Elasticsearch:basic
илиplatinum
. -
Проверьте корректность настроек.
-
В командной строке перейдите в каталог, в котором расположены актуальные конфигурационные файлы Terraform с планом инфраструктуры.
-
Выполните команду:
terraform validate
Если в файлах конфигурации есть ошибки, Terraform на них укажет.
-
-
Подтвердите изменение ресурсов.
-
Выполните команду для просмотра планируемых изменений:
terraform plan
Если конфигурации ресурсов описаны верно, в терминале отобразится список изменяемых ресурсов и их параметров. Это проверочный этап: ресурсы не будут изменены.
-
Если вас устраивают планируемые изменения, внесите их:
-
Выполните команду:
terraform apply
-
Подтвердите изменение ресурсов.
-
Дождитесь завершения операции.
-
-
Подробнее см. в документации провайдера Terraform
Ограничения по времени
Провайдер Terraform ограничивает время на выполнение операций с кластером Managed Service for Elasticsearch:
- создание, в т. ч. путем восстановления из резервной копии, — 30 минут;
- изменение — 60 минут;
- удаление — 15 минут.
Операции, длящиеся дольше указанного времени, прерываются.
Как изменить эти ограничения?
Добавьте к описанию кластера блок timeouts
, например:
resource "yandex_mdb_elasticsearch_cluster" "<имя_кластера>" {
...
timeouts {
create = "1h30m" # Полтора часа
update = "2h" # 2 часа
delete = "30m" # 30 минут
}
}
Чтобы изменить редакцию Elasticsearch, воспользуйтесь методом REST API update для ресурса Cluster или вызовом gRPC API ClusterService/Update и передайте в запросе:
-
Идентификатор кластера в параметре
clusterId
.Идентификатор кластера можно получить со списком кластеров в каталоге.
-
Новую редакцию Elasticsearch в параметре
configSpec.edition
. -
Список изменяемых полей конфигурации кластера в параметре
updateMask
(в данном случае —configSpec.edition
).
Важно
Метод API переопределит все параметры изменяемого объекта, которые не были явно переданы в запросе, на значения по умолчанию. Чтобы избежать этого, перечислите настройки, которые вы хотите изменить, в параметре updateMask
(одной строкой через запятую).